commit 2ec3765616ff7d29c01748c5c9f55df7078d650f Author: Jean Ouina Date: Sat May 16 23:24:51 2020 +0200 :flushed: diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..e47f93e --- /dev/null +++ b/.gitignore @@ -0,0 +1,111 @@ +# Logs +logs +*.log +npm-debug.log* +yarn-debug.log* +yarn-error.log* +lerna-debug.log* + +# Diagnostic reports (https://nodejs.org/api/report.html) +report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json + +# Runtime data +pids +*.pid +*.seed +*.pid.lock + +# Directory for instrumented libs generated by jscoverage/JSCover +lib-cov + +# Coverage directory used by tools like istanbul +coverage +*.lcov + +# nyc test coverage +.nyc_output + +# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) +.grunt + +# Bower dependency directory (https://bower.io/) +bower_components + +# node-waf configuration +.lock-wscript + +# Compiled binary addons (https://nodejs.org/api/addons.html) +build/Release + +# Dependency directories +node_modules/ +jspm_packages/ + +# TypeScript v1 declaration files +typings/ + +# TypeScript cache +*.tsbuildinfo + +# Optional npm cache directory +.npm + +# Optional eslint cache +.eslintcache + +# Microbundle cache +.rpt2_cache/ +.rts2_cache_cjs/ +.rts2_cache_es/ +.rts2_cache_umd/ + +# Optional REPL history +.node_repl_history + +# Output of 'npm pack' +*.tgz + +# Yarn Integrity file +.yarn-integrity + +# dotenv environment variables file +.env +.env.test + +# parcel-bundler cache (https://parceljs.org/) +.cache + +# Next.js build output +.next + +# Nuxt.js build / generate output +.nuxt +dist + +# Gatsby files +.cache/ +# Comment in the public line in if your project uses Gatsby and *not* Next.js +# https://nextjs.org/blog/next-9-1#public-directory-support +# public + +# vuepress build output +.vuepress/dist + +# Serverless directories +.serverless/ + +# FuseBox cache +.fusebox/ + +# DynamoDB Local files +.dynamodb/ + +# TernJS port file +.tern-port + +# no build on github +builds + +# must build typescript itself +dist + diff --git a/BetterDiscordApp/.eslintrc b/BetterDiscordApp/.eslintrc new file mode 100644 index 0000000..672611b --- /dev/null +++ b/BetterDiscordApp/.eslintrc @@ -0,0 +1,54 @@ +{ + "extends": ["eslint:recommended", "plugin:react/recommended"], + "plugins": [ + "react" + ], + "env": { + "browser": true, + "node": true, + "jquery": true + }, + "parserOptions": { + "ecmaVersion": 8, + "sourceType": "module", + "ecmaFeatures": { + "jsx": true + } + }, + "rules": { + "semi": 2, + "space-infix-ops": ["error", {"int32Hint": false}], + "quotes": ["error", "double", {"allowTemplateLiterals": true}], + "no-console": 0, + "brace-style": ["error", "stroustrup", {"allowSingleLine": true}], + "keyword-spacing": 2, + "no-else-return": 2, + "curly": ["error", "multi-line", "consistent"], + "dot-notation": 2, + "yoda": 2, + "linebreak-style": ["error", "windows"], + "quote-props": ["error", "consistent-as-needed", {"keywords": true}], + "object-curly-spacing": ["error", "never", { "objectsInObjects": false }], + "no-var": "error", + "prefer-const": "error", + "react/jsx-uses-react": "error", + "react/jsx-uses-vars": "error", + "react/prop-types": "off", + "react/jsx-no-target-blank": "error", + "react/jsx-key": "off" + }, + "globals": { + "webpackJsonp": false, + "Proxy": false, + "Set": false, + "WeakMap": false, + "Promise": false, + "ace": false, + "Reflect": false, + "Array": false, + "DiscordNative": false, + "self": "off", + "name": "off", + "__non_webpack_require__": false + } +} \ No newline at end of file diff --git a/BetterDiscordApp/.gitignore b/BetterDiscordApp/.gitignore new file mode 100644 index 0000000..b512c09 --- /dev/null +++ b/BetterDiscordApp/.gitignore @@ -0,0 +1 @@ +node_modules \ No newline at end of file diff --git a/BetterDiscordApp/LICENSE b/BetterDiscordApp/LICENSE new file mode 100644 index 0000000..c19c6dc --- /dev/null +++ b/BetterDiscordApp/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2015-present Jiiks | 2017-present Zack Rauen + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/BetterDiscordApp/README.md b/BetterDiscordApp/README.md new file mode 100644 index 0000000..e02c580 --- /dev/null +++ b/BetterDiscordApp/README.md @@ -0,0 +1,159 @@ +# BandagedBD [![Patreon][patreon-badge]][patreon-link] [![Paypal][paypal-badge]][paypal-link] +[patreon-badge]: https://img.shields.io/endpoint.svg?url=https%3A%2F%2Fshieldsio-patreon.herokuapp.com%2FZerebos&style=flat-square +[patreon-link]: https://patreon.com/Zerebos + +[paypal-badge]: https://img.shields.io/badge/Paypal-Donate!-%2300457C.svg?logo=paypal&style=flat-square +[paypal-link]: https://paypal.me/ZackRauen + +BandagedBD (Bandaged BetterDiscord) is a fork of the original [BetterDiscord](https://github.com/Jiiks/BetterDiscordApp) by Jiiks. This has a number of improvements over the original. The original version has been unmaintained hence this fork existing. There have been attempts to rewrite the original that I have been and will continue to be involved in, but in the meantime I will continue to maintain and improve BBD. + +# Installation + +## Auto Installers + +### Windows +Grab the `exe` file from [here](https://github.com/rauenzi/BetterDiscordApp/releases/latest/download/BandagedBD_Windows.exe). + +### macOS/OS X +Grab the `zip` file from [here](https://github.com/rauenzi/BetterDiscordApp/releases/latest/download/BandagedBD_Mac.zip). + +### Linux +See this [gist](https://gist.github.com/ObserverOfTime/d7e60eb9aa7fe837545c8cb77cf31172). + +## Manual Installation + +### Windows +1. Download and extract this: https://github.com/rauenzi/BetterDiscordApp/archive/injector.zip +2. Rename `BetterDiscordApp-injector` to `app`. +3. Go to `%localappdata%\Discord\`, and locate the directory with the largest version number (e.g. `app-0.0.306`). +4. Within `app-0.0.306` navigate to `resources`. +5. If an `app` folder already exists inside `resources`, delete it. +6. Move the `app` folder (the one you downloaded and renamed) inside of `resources`. +7. Fully quit Discord and restart it. + +### macOS/OS X +1. Download and extract this: https://github.com/rauenzi/BetterDiscordApp/archive/injector.zip +2. Rename `BetterDiscordApp-injector` to `app`. +3. Go to `/Applications/`, right click `Discord.app` and select `Show Package Contents`. +4. Within `Discord.app` navigate to `Contents` -> `Resources`. +5. If an `app` folder already exists inside `Resources`, delete it. +6. Move the `app` folder (the one you downloaded and renamed) inside of `Resources`. +7. Fully quit Discord and restart it. + +# FAQ + +### What is this? +This is a client modification for Discord. It allows you to add plugins and themes to your client. Plugins can add functionality and useful features. Themes can completely change the look and feel of Discord. + +BBD has some other built-in features such as Emotes from Twitch, FFZ, and BBTV, as well as an in-client server browser. + +### Where can I get plugins and themes? +In our support servers we have channels with lists of official plugins and themes. Please note we do not have an official listing on a website and are **not affiliated with any of those websites**. + +### Support Servers? +There are two: [The main server](https://discord.gg/0Tmfo5ZbORCRqbAd), and [the backup](https://discord.gg/2HScm8j). + + + +# Supporters +These people have all subscribed to the `True Supporter` tier on Patreon to support BandagedBD. + + + + + + + + + + +
+ Kraken
+ Kraken
+
+ SPHHAX
+ SPHHAX
+
+ DefCon42
+ DefCon42
+
+ Justxn
+ Justxn
+
+ monkey
+ monkey
+
+ + +# Bandagers +These people have all subscribed to the `Bandager` tier on Patreon to support BandagedBD. + + + + + + + + + +
+ William JCM
+ William JCM +
+ NFLD99
+ NFLD99 +
+ Gibbu
+ Gibbu +
+ Tenuit
+ Tenuit +
+ +# Donors +These people have either donated or subscribed to the most basic patron tier to support BandagedBD. + + + + + + + + + + + + + + +
+
+ aetheryx +
+
+ JBeauDee +
+
+ vantiss +
+
+ xstefen +
+
+ 『Sorey』 +
+
+ LiVeR +
+
+ SweetLilyCake +
+
+ GameKuchen +
+
+ Lozo +
+
+ Akira +
diff --git a/BetterDiscordApp/css/main.css b/BetterDiscordApp/css/main.css new file mode 100644 index 0000000..382bc56 --- /dev/null +++ b/BetterDiscordApp/css/main.css @@ -0,0 +1,2136 @@ +:root { + --bd-blue: #3E82E5; + --bd-blue-hover: rgb(56,117,206); + --bd-blue-active: rgb(50,104,183); + --blurple: #7289DA; +} + +/* BEGIN V2 LOADER */ +/* =============== */ + +.bd-loaderv2 { + background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+IDwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+PHN2ZyBoZWlnaHQ9IjEwMCUiIHN0eWxlPSJmaWxsLXJ1bGU6ZXZlbm9kZDtjbGlwLXJ1bGU6ZXZlbm9kZDtzdHJva2UtbGluZWNhcDpyb3VuZDtzdHJva2UtbGluZWpvaW46cm91bmQ7IiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWw6c3BhY2U9InByZXNlcnZlIiB3aWR0aD0iMTAwJSIgdmVyc2lvbj0iMS4xIiB2aWV3Qm94PSIwIDAgMjAwMCAyMDAwIj4gICAgPG1ldGFkYXRhIC8+ICAgIDxkZWZzPiAgICAgICAgPGZpbHRlciBpZD0ic2hhZG93MSI+ICAgICAgICA8ZmVEcm9wU2hhZG93IGR4PSIyMCIgZHk9IjAiIHN0ZERldmlhdGlvbj0iMjAiIGZsb29kLWNvbG9yPSJyZ2JhKDAsMCwwLDAuMzUpIi8+ICAgICAgICA8L2ZpbHRlcj4gICAgICAgIDxmaWx0ZXIgaWQ9InNoYWRvdzIiPiAgICAgICAgPGZlRHJvcFNoYWRvdyBkeD0iMTUiIGR5PSIwIiBzdGREZXZpYXRpb249IjIwIiBmbG9vZC1jb2xvcj0icmdiYSgyNTUsMjU1LDI1NSwwLjE1KSIvPiAgICAgICAgPC9maWx0ZXI+ICAgICAgICA8ZmlsdGVyIGlkPSJzaGFkb3czIj4gICAgICAgIDxmZURyb3BTaGFkb3cgZHg9IjEwIiBkeT0iMCIgc3RkRGV2aWF0aW9uPSIyMCIgZmxvb2QtY29sb3I9InJnYmEoMCwwLDAsMC4zNSkiLz4gICAgICAgIDwvZmlsdGVyPiAgICA8L2RlZnM+ICAgIDxnPiAgICAgICAgPHBhdGggc3R5bGU9ImZpbHRlcjogdXJsKCNzaGFkb3czKSIgZD0iTTExOTUuNDQrMTM1LjQ0MkwxMTk1LjQ0KzEzNS40NDJMOTk3LjYrMTM2LjQ0MkMxMDI0LjIrMTQ5Ljc0MisxMTcwLjM0KzE2My41NDIrMTE5My42NCsxNzkuNzQyQzEyNjQuMzQrMjI4Ljg0MisxMzE5Ljc0KzI5MS4yNDIrMTM1OC4yNCszNjUuMDQyQzEzOTguMTQrNDQxLjY0MisxNDE5Ljc0KzUzMC42NDIrMTQyMi41NCs2MjkuNjQyTDE0MjIuNTQrNjMwLjg0MkwxNDIyLjU0KzYzMi4wNDJDMTQyMi41NCs3NzMuMTQyKzE0MjIuNTQrMTIyOC4xNCsxNDIyLjU0KzEzNjkuMTRMMTQyMi41NCsxMzcwLjM0TDE0MjIuNTQrMTM3MS41NEMxNDE5Ljg0KzE0NzAuNTQrMTM5OC4yNCsxNTU5LjU0KzEzNTguMjQrMTYzNi4xNEMxMzE5Ljc0KzE3MDkuOTQrMTI2NC40NCsxNzcyLjM0KzExOTMuNjQrMTgyMS40NEMxMTcxLjA0KzE4MzcuMTQrMTAyNS43KzE4NTAuNTQrMTAwMCsxODYzLjU0TDExOTMuNTQrMTg2NC41NEMxNTM5Ljc0KzE4NjYuNDQrMTg2NC41NCsxNjkzLjM0KzE4NjQuNTQrMTI5Ni42NEwxODY0LjU0KzcxNi45NDJDMTg2Ni40NCszMTIuNDQyKzE1NDEuNjQrMTM1LjQ0MisxMTk1LjQ0KzEzNS40NDJaIiBmaWxsPSIjMTcxNzE3IiBvcGFjaXR5PSIxIi8+ICAgICAgICA8cGF0aCBzdHlsZT0iZmlsdGVyOiB1cmwoI3NoYWRvdzIpIiBkPSJNMTY5NS41NCs2MzEuNDQyQzE2ODUuODQrMjc4LjA0MisxNDA5LjM0KzEzNS40NDIrMTA1Mi45NCsxMzUuNDQyTDM2MS43NCsxMzYuNDQyTDgwMy43NCs0OTAuNDQyTDEwNjAuNzQrNDkwLjQ0MkMxMzM1LjI0KzQ5MC40NDIrMTMzNS4yNCs4MzUuMzQyKzEwNjAuNzQrODM1LjM0MkwxMDYwLjc0KzExNjQuODRDMTE1MC4yMisxMTY0Ljg0KzEyMTAuNTMrMTIwMS40OCsxMjQxLjY4KzEyNTAuODdDMTMwNi4wNysxMzUzKzEyNDUuNzYrMTUwOS42NCsxMDYwLjc0KzE1MDkuNjRMMzYxLjc0KzE4NjMuNTRMMTA1Mi45NCsxODY0LjU0QzE0MDkuMjQrMTg2NC41NCsxNjg1Ljc0KzE3MjEuOTQrMTY5NS41NCsxMzY4LjU0QzE2OTUuNTQrMTIwNS45NCsxNjUxLjA0KzEwODQuNDQrMTU3Mi42NCs5OTkuOTQyQzE2NTEuMDQrOTE1LjU0MisxNjk1LjU0Kzc5NC4wNDIrMTY5NS41NCs2MzEuNDQyWiIgZmlsbD0iIzNFODJFNSIgb3BhY2l0eT0iMSIvPiAgICAgICAgPHBhdGggc3R5bGU9ImZpbHRlcjogdXJsKCNzaGFkb3cxKSIgZD0iTTE0NjkuMjUrNjMxLjQ0MkMxNDU5LjU1KzI3OC4wNDIrMTE4My4wNSsxMzUuNDQyKzgyNi42NSsxMzUuNDQyTDEzNS40NSsxMzUuNDQyTDEzNS40NSsxMDA0QzEzNS40NSsxMDA0KzEzNS40MjcrMTI1NS4yMSszNTUuNjI2KzEyNTUuMjFDNTc1LjgyNSsxMjU1LjIxKzU3NS44NDgrMTAwNCs1NzUuODQ4KzEwMDRMNTc3LjQ1KzQ5MC40NDJMODM0LjQ1KzQ5MC40NDJDMTEwOC45NSs0OTAuNDQyKzExMDguOTUrODM1LjM0Mis4MzQuNDUrODM1LjM0Mkw2NjQuNjUrODM1LjM0Mkw2NjQuNjUrMTE2NC44NEw4MzQuNDUrMTE2NC44NEM5MjMuOTMyKzExNjQuODQrOTg0LjI0NCsxMjAxLjQ4KzEwMTUuMzkrMTI1MC44N0MxMDc5Ljc4KzEzNTMrMTAxOS40NysxNTA5LjY0KzgzNC40NSsxNTA5LjY0TDEzNS40NSsxNTA5LjY0TDEzNS40NSsxODY0LjU0TDgyNi42NSsxODY0LjU0QzExODIuOTUrMTg2NC41NCsxNDU5LjQ1KzE3MjEuOTQrMTQ2OS4yNSsxMzY4LjU0QzE0NjkuMjUrMTIwNS45NCsxNDI0Ljc1KzEwODQuNDQrMTM0Ni4zNSs5OTkuOTQyQzE0MjQuNzUrOTE1LjU0MisxNDY5LjI1Kzc5NC4wNDIrMTQ2OS4yNSs2MzEuNDQyWiIgZmlsbD0iI0ZGRkZGRiIgb3BhY2l0eT0iMSIvPiAgICA8L2c+PC9zdmc+); +} +.bd-loaderv2 { + position: fixed; + bottom:5px; + right:5px; + z-index: 2147483647; + display: block; + width: 20px; + height: 20px; + background-size: 100% 100%; + animation: bd-loaderv2-animation 1.5s ease-in-out infinite; +} + +@keyframes bd-loaderv2-animation { + 0% { opacity: 0.05; } + 50% { opacity: 0.6; } + 100% { opacity: 0.05; } +} +/* =============== */ +/* END V2 LOADER */ + + +.bd-button { + background-color: var(--bd-blue); + color: white; + border-radius: 3px; + padding: 2px 6px; +} + +.bd-button:hover { + background-color: var(--bd-blue-hover); +} + +.bd-button:active { + background-color: var(--bd-blue-active); +} + +.bd-button.bd-button-success { + background-color: #3ac15c; +} + +.bd-button.bd-button-success:hover { + background-color: rgb(52,174,83); +} + +.bd-button.bd-button-success:active { + background-color: rgb(46,154,74); +} + +.bd-button + .bd-button { + margin-left: 5px; +} + +.bd-button-outline { + background-color: transparent; + border: 2px solid white; +} + + + + + +/* BEGIN EMOTE STYLING */ +/* =================== */ +#emote-container { + padding: 10px; +} + +.emote-container { + display: inline-block; + padding: 2px; + border-radius: 5px; + width: 30px; + height: 30px; + position: relative; +} + +.emote-icon { + max-width: 100%; + max-height: 100%; + position: absolute; + margin: auto; + top: 0; + right: 0; + bottom: 0; + left: 0; + cursor: pointer; +} + +.emote.stop-animation {animation: none!important;} + +.emote-container:hover { + background: rgba(123, 123, 123, 0.37); +} + +.emoteflip, .emotespinflip { + transform: scaleX(-1); +} + +.emotespin { + animation: 1s emote-spin infinite linear; +} + +.emote1spin { + animation: 1s emote-spin-reverse infinite linear; +} + +.emotespin2 { + animation: 0.5s emote-spin infinite linear; +} + +.emote2spin { + animation: 0.5s emote-spin-reverse infinite linear; +} + +.emotespin3 { + animation: 0.2s emote-spin infinite linear; +} + +.emote3spin { + animation: 0.2s emote-spin-reverse infinite linear; +} + +.emotepulse { + animation: 1s emote-pulse infinite linear; +} + +.emotetr { + transform: translateX(-3px); +} + +.emotebl { + transform: translateY(-3px); +} + +.emotebr { + transform: translate(-3px, -3px); +} + +.emoteshake { + animation: 1s emote-shake infinite linear; +} + +.emoteflap { + transform: scaleY(-1) !important; +} + +.emoteshake2 { + animation: emote-shake2 0.3s linear infinite; +} + +.emoteshake3 { + animation: emote-shake3 0.1s linear infinite; +} + +@keyframes emote-shake2 { + 25% { + transform: translate(-1px, -1px); + } + 50% { + transform: translate(-1px, 1px); + } + 75% { + transform: translate(1px, 1px); + } + 75% { + transform: translate(1px, -1px); + } +} +@keyframes emote-shake3 { + 25% { + transform: translate(-1px, -1px); + } + 50% { + transform: translate(-1px, 1px); + } + 75% { + transform: translate(1px, 1px); + } + 75% { + transform: translate(1px, -1px); + } +} +@keyframes emote-spin { + from { + transform: rotate(0deg); + } + to { + transform: rotate(360deg); + } +} +@keyframes emote-spin-reverse { + from { + transform: rotate(0deg); + } + to { + transform: rotate(-360deg); + } +} +@keyframes emote-pulse { + 0% { + -webkit-transform: scale(1, 1); + } + 50% { + -webkit-transform: scale(1.2, 1.2); + } + 100% { + -webkit-transform: scale(1, 1); + } +} +@keyframes emote-shake { + 10%, 90% { + transform: translate3d(-1px, 0, 0); + } + 20%, 80% { + transform: translate3d(2px, 0, 0); + } + 30%, 50%, 70% { + transform: translate3d(-4px, 0, 0); + } + 40%, 60% { + transform: translate3d(4px, 0, 0); + } +} +/* =================== */ +/* END EMOTE STYLING */ + +/* BEGIN EMOTE MENU */ +/* ================ */ + +#removemenu { + width: auto; + background: #505050; + position: absolute; + z-index: 999999; + display: none; + box-shadow: 0 0 2px #000; + padding: 2px; + left: 25px; + display: block !important; + cursor: pointer; + color: #FFF; + position: fixed; +} +#removemenu ul a { + text-decoration: none; + color: #FFF; + padding: 3px; +} + +.emotewrapper { + position: relative; + display: inline-flex; + object-fit: contain; + margin: -.1em .05em -.2em .1em; + vertical-align: top; +} + +.emotewrapper.jumboable { + margin-bottom: 0; + margin-top: .2em; + vertical-align: -.3em; +} + +.emote { + height: 1.45em; +} + +.emote.jumboable { + height: 2rem; +} + +.emotewrapper:hover .fav { + display: block; +} + +.fav { + display: none; + position: absolute; + width: 15px; + height: 15px; + right: -7px; + background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAAAzFBMVEUAAABQUFBMTExLS0tNTU1MTExNTU1NTU1MTExMTExNTU1LS0tEREBEREBEREBEREBJSUhLS0tLS0tEREBNTU1NTU1NTU1EREArKyhNTU1NTU0AAABMTExKSklMTExNTU1NTU1NTU1KSkpMTExKSkhNTU1KSkpISEZNTU1LS0tAQDxOTk5KSkpLS0tNTU1MTExMTEx/f39MTExMTExLS0pLS0tMTExNTU1NTU1LS0pNTU1NTU1NTU1NTU1NTU1NTUxNTU1NTU1NTUxMTEzB8C/5AAAAOnRSTlMAI8X96oWAgYSF68QBAg0PMCb9BIuLgQUD4N0Bh0mKhZSOQ4gcrKscaW8QRE6fmJyjAshASceG7cIpqQOxTQAAALVJREFUGFddx6FOA0EYAOGZvd07Qm6vVCAAgUUgQEDfX/YZMAigqaFN7iC5tsmPqGPUN/AvUVeoEbGOCElJz08Uzeixqu4AqomVVSNngOVjTqDGZSl3UFtPGV2ot2zaq96YM9p5Ddzcf/nTTAlj+/sNtNu8OcwkIsbPBtrUfMQeEhGQmHbmGIFMwLPzu6UMIwBNgToshgq8Nr2ki+Oy7ebDHp70LRPWB6OZgfWLWei7fJonOOsPCGA9kVlssOoAAAAASUVORK5CYII="); + border: none; + background-size: 100% 100%; + background-repeat: no-repeat; + background-color: #303030; + border-radius: 5px; + top: -7px; + cursor: pointer; +} + +.fav.active { + background-color: yellow; +} + +.emojiPicker-3m1S-j { + box-shadow: none; + border-top: none; + border-radius: 0 0 5px 5px; +} + +#bda-qem { + border-radius: 5px 5px 0 0; + background: #2f3136; + border-bottom: 1px solid rgba(0, 0, 0, 0.1) !important; + height: 30px; + display: flex; + flex-direction: row; + padding-right: 1px !important; +} + +.theme-light #bda-qem { + background: #f2f3f5; +} + +#bda-qem button { + border-left: 1px solid #202225; + background: #2f3136; + box-shadow: rgba(0, 0, 0, 0.1) 1px 0 0 0; + flex-grow: 1; + color: #FFF; +} + +.theme-light #bda-qem button { + border-left: 1px solid #EFEFEF; + background: transparent; + box-shadow: #CECECE 1px 0 0 0; + color: #000; +} + +#bda-qem button:first-child { + border-left-color: transparent; +} + +#bda-qem button:hover { + background: rgba(79,84,92,0.16); +} + +.theme-light #bda-qem button:hover { + background: #ECECEC; +} + +#bda-qem-twitch { + border-radius: 5px 0 0 0; + order: 2; +} + +#bda-qem-emojis { + border-radius: 0 5px 0 0; + order: 3; +} + +#bda-qem-favourite { + order: 3; +} + +#bda-qem button.active, +#bda-qem button.active:hover { + background-color: var(--bd-blue); +} + +.theme-light #bda-qem button.active, +.theme-light #bda-qem button.active:hover { + color: #ffffff; +} + +#bda-qem-twitch-container, +#bda-qem-favourite-container { + width: 384px; + height: 424px; + background-color: #2f3136; + border-radius: 0 0 5px 5px; +} + +.theme-light #bda-qem-twitch-container, +.theme-light #bda-qem-favourite-container { + background-color: #f2f3f5; +} + +#bda-qem-twitch-container .scroller-wrap, #bda-qem-favourite-container .scroller-wrap { + height: 100%; +} + +.emote-menu-inner { + padding: 5px 0 0 15px; +} + +.bda-qme-hidden #bda-qem-emojis { + display: none; +} +/* ================ */ +/* END EMOTE MENU */ + + + + + +/* BEGIN PUBLIC SERVERS */ +/* ==================== */ +#bd-pub-li { + height: 20px; + margin-bottom: 10px; + overflow: hidden; +} + +#bd-pub-button { + border-radius: 4px; + background-color: rgb(47, 49, 54); + color: #b9bbbe; + text-align: center; + font-size: 12px; + line-height: 20px; + height: 20px; +} + +.bd-server-card .bd-server-tags { + flex: 1 1 auto; + text-overflow: ellipsis; + white-space: nowrap; + overflow: hidden; + width: 0; + line-height: 24px; + font-size: 12px; + color: #b9bbbe; + font-weight: 700; + margin-right: 10px; +} + +.ui-card.ui-card-primary.bd-server-card:first-child { + margin-bottom: 13px; +} + +.ui-card.ui-card-primary.bd-server-card:first-child:after { + border: 3px solid var(--bd-blue); + content: ""; + display: block; + position: absolute; + left: 0; + right: 0; + margin-top: 4px; +} + +.bd-server-card.bd-server-card-pinned { + margin-bottom: 15px; +} + +.bd-server-card.bd-server-card-pinned:after { + background: #3a71c1; + content: ""; + height: 3px; + width: 100%; + display: block; + margin-top: 7px; + position: absolute; + top: 100%; +} + +.bd-server-description-container { + color: #b9bbbe; + min-height: 65px; + max-height: 65px; + border-top: 1px solid #3f4146; + border-bottom: 1px solid #3f4146; + padding-top: 5px; + font-size: 13px; +} + +.bd-server-header { + justify-content: space-between; + font-weight: 600; +} + +.bd-server-card { + display: flex; +} + +.bd-server-content { + padding: 5px 10px; + flex: 1; +} + +.bd-server-image { + min-width: 115px; + min-height: 115px; + max-width: 115px; + max-height: 115px; +} + +.bd-server-name { + text-overflow: ellipsis; + white-space: nowrap; + overflow: hidden; + padding-right: 15px; + max-width: 330px; + flex: 1 1 50%; +} + +.bd-layer { + -ms-flex-direction: column; + -webkit-box-direction: normal; + -webkit-box-orient: vertical; + bottom: 0; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + flex-direction: column; + left: 0; + position: absolute; + right: 0; + top: 0; +} +#pubslayer .ui-tab-bar-item { + color: #b9bbbe; + padding-top: 6px; + padding-bottom: 6px; + margin-bottom: 2px; + padding: 6px 10px; + position: relative; + font-size: 16px; + line-height: 20px; + border-radius: 3px; + white-space: nowrap; + text-overflow: ellipsis; + overflow: hidden; + flex-shrink: 0; + font-weight: 500; + cursor: pointer; +} + +#pubslayer .ui-tab-bar-item:hover { + color: #f6f6f7; + background-color: hsla(216,4%,74%,.1); +} + +#pubslayer .ui-tab-bar-item.selected { + color: #fff; + background-color: var(--bd-blue); +} + +#pubslayer .ui-tab-bar-header { + color: #72767d; + padding: 6px 10px; + font-size: 12px; + line-height: 16px; + text-transform: uppercase; + white-space: nowrap; + text-overflow: ellipsis; + overflow: hidden; + flex-shrink: 0; + font-weight: 500; +} + +#pubslayer #bd-settings-sidebar .ui-tab-bar-separator { + background-color: hsla(218,5%,47%,.3); + margin-left: 10px; + margin-right: 10px; + height: 1px; + margin-bottom: 8px; + margin-top: 8px; +} + +#pubslayer h2.ui-form-title { + color: #f6f6f7; + text-transform: uppercase; + font-weight: 600; +} + +#pubslayer h5.ui-form-title { + color: #f6f6f7; +} + +#pubslayer button { +background: var(--bd-blue); + color: #FFF; + font-size: 14px; + font-weight: 500; + line-height: 16px; + padding: 2px 16px; + border: none; + border-radius: 3px; + transition: background-color .17s ease; +} + +#pubslayer button:hover { +background-color: #677bc4; +} + +#pubslayer input { +color: #f6f6f7; + background-color: rgba(0,0,0,.1); + border-color: rgba(0,0,0,.3); + padding: 10px; + height: 30px; + border-width: 1px; + border-style: solid; + border-radius: 3px; + outline: none; + transition: background-color .15s ease,border .15s ease; +} +/* ==================== */ +/* END PUBLIC SERVERS */ + + + + + +/* BEGIN CSS EDITOR */ +/* ================ */ +.standardSidebarView-3F1I7i #bd-customcss-attach-controls button, +.bd-detached-css-editor #bd-customcss-attach-controls button { + margin: 0; + width: 100px; + background: #31332b; + color: #FFF; + height: 26px; + font-weight: 600; + margin-top: 5px; + border-radius: 3px; +} + +.standardSidebarView-3F1I7i #bd-customcss-attach-controls button:hover, +.bd-detached-css-editor #bd-customcss-attach-controls button:hover { + background: #3b3e44; +} + +.contentRegion-3nDuYy #bd-customcss-attach-controls, +#bd-customcss-detach-container #bd-customcss-attach-controls { + background: #272822; + color: #FFF; + border: none; + box-shadow: 0px 1px 0px 0px #2F3129 inset; +} + + +.contentRegion-3nDuYy #bd-customcss-pane, +.contentRegion-3nDuYy #bd-customcss-innerpane, +#bd-customcss-detach-container #bd-customcss-pane, +#bd-customcss-detach-container #bd-customcss-innerpane { + min-height: calc(80vh - 165px); +} + +.standardSidebarView-3F1I7i #editor-detached h3 { + color: #87909c; + font-weight: 600; + font-size: 22px; +} +.standardSidebarView-3F1I7i #editor-detached button { + margin: auto; + margin-left: calc(50% - 100px); + margin-top: 20px; + background: var(--bd-blue); + color: #FFF; + font-weight: 600; + border-radius: 5px; + font-size: 20px; +} + +.editor-wrapper { + display: flex; +} + +.line-numbers, .ace_editor { + line-height: normal; + font-family: Consolas, monospace; + box-sizing: border-box; + height: calc(100vh - 250px); + font-size: 14px; +} + +.line-numbers { + white-space: pre; + color: gray; + padding: 10px 5px 0 5px; + background: #24262a; + overflow: hidden; +} + +.ace_editor { + width: 100%; + background: #292B2F; + outline: none; + color: white; + padding: 10px; + resize: none; +} + +#bd-customcss-detach-container .editor-wrapper, +#bd-customcss-detach-container .line-numbers, +#bd-customcss-detach-container .ace_editor { + height: 100%; +} + +.bd-detached-editor .app-2rEoOp { + width: 70%; +} + +.bd-detached-editor #bd-customcss-detach-container { + display: block; +} + +#bd-customcss-detach-container { + display: none; + position: absolute; + width: 30%; + top: 0; + right: 0; + bottom: 0; + background-color: #36393e; +} + +#bd-customcss-detach-editor { + height: calc(100% - 87px); +} +#bd-customcss-detach-editor #bd-customcss-innerpane, #bd-customcss-detach-editor .CodeMirror { + height: 100%; +} + +#bd-customcss-detach-controls { + background: #E8E8E8; + border-top: 1px solid #ADADAD; + box-shadow: inset 0px 1px 0px 0px white; + height: 100%; + padding: 5px; +} +#bd-customcss-detach-controls .checkbox-group li { + margin-top: 5px; + display: inline-block; +} +#bd-customcss-detach-controls button { + width: 90px; + height: 30px; + margin-top: 8px; + background-color: #738bd7; + color: #fff; + font-size: 19px; +} + +#bd-customcss-detach-controls-buttons { + bottom: 5px; +} + +#editor-detached { + margin-top: 50px; +} +#editor-detached h3 { + text-align: center; + font-size: 30px; +} +#editor-detached .btn { + left: 50%; + margin-left: -100px; + margin-top: 10px; + width: 200px; + height: 60px; +} + +#bd-customcss-attach-controls { + background: #E8E8E8; + border: 1px solid #FFF; + border-top: 1px solid #ADADAD; + box-shadow: inset 0px 1px 0px 0px white; + height: 100%; + padding: 5px; +} +#bd-customcss-attach-controls .checkbox-group { + margin-bottom: 0; +} +#bd-customcss-attach-controls .checkbox-group li { + margin-top: 5px; + display: inline-block; +} +#bd-customcss-attach-controls button { + margin: 0; + width: 100px; +} + +#bd-customcss-detach-container #bd-customcss-detach-controls-buttons button { + width: 90px; + height: 30px; + margin-top: 8px; + background-color: #738bd7; + color: #fff; + font-size: 19px; +} + +/* Ace Editor Settings */ +#ace_settingsmenu_container { + background: rgba(0,0,0, 0.7)!important; +} + +body #ace_settingsmenu { + padding-top: 35px; +} + +body .ace_closeButton { + position: absolute; + top: 8px; + right: 12px; + z-index: 10000; + padding: 0; + cursor: pointer; + background: none; + border: none; +} + +body .ace_closeButton::before { + content: "✖"; + color: #36393f; +} + +body .ace_closeButton:active { + transform: translateY(2px); +} + +.theme-dark div #ace_settingsmenu { + color: #f6f6f7; + background: #36393f; + box-shadow: 0 0 0 1px rgba(32,34,37,.6),0 2px 10px 0 rgba(0,0,0,.2); +} + +.theme-dark div #ace_settingsmenu select, +.theme-dark div #ace_settingsmenu input[type="text"] { + color: #f6f6f7; + background: #2F3136; + border: 1px solid #484B52; +} + +.theme-dark div .ace_closeButton::before { + color: #f6f6f7; +} + +/* editor help text */ +#bd-customcss-attach-controls .help-text { + margin-top: 8px; + margin-bottom: 3px; + font-size: 14px; +} + +#bd-customcss-attach-controls .help-text .inline { + background: #31332B; + padding: .2em; + margin: -.2em 0; + border-radius: 3px; +} +/* ================ */ +/* END CSS EDITOR */ + + + + + +/* BEGIN BD SETTINGS */ +/* ================= */ + +.bd-social-logo { + opacity: 0.6; +} + +.bd-social-link:hover .bd-social-logo { + opacity: 1; +} + +.standardSidebarView-3F1I7i .bd-versioninfo-wrapper { + bottom: 0; + left: 0; + position: fixed; + background: inherit; + right: 0; + padding: 5px; +} + +.standardSidebarView-3F1I7i .bd-versioninfo-wrapper span { + color: #b9bbbe; + font-weight: 600; + font-size: 11px; +} + +.standardSidebarView-3F1I7i .bd-versioninfo-wrapper a { + font-size: 11px; +} + +.bd-pfbtn { + background: var(--bd-blue); + color: #FFF; + border-radius: 5px; + margin-left: 10px; +} + +#bd-settings-sidebar .ui-tab-bar-item { + font-size: 16px; + font-weight: 500; + line-height: 20px; + text-overflow: ellipsis; + white-space: nowrap; + cursor: pointer; + flex-shrink: 0; + padding: 6px 10px; + border-radius: 3px; + position: relative; + overflow: hidden; +} +#bd-settings-sidebar .ui-tab-bar-item.selected { + cursor: default; +} +.theme-dark #bd-settings-sidebar .ui-tab-bar-item { + color: #b9bbbe; +} +.theme-dark #bd-settings-sidebar .ui-tab-bar-item:hover { + background-color: rgba(185,187,190,.1); + color: #f6f6f7; +} +.theme-dark #bd-settings-sidebar .ui-tab-bar-item.selected { + background-color: var(--bd-blue); + color: #fff; +} +.theme-light #bd-settings-sidebar .ui-tab-bar-item { + color: #72767d; +} +.theme-light #bd-settings-sidebar .ui-tab-bar-item:hover { + background-color: rgba(79,84,92,.1); + color: #4f545c; +} +.theme-light #bd-settings-sidebar .ui-tab-bar-item.selected { + background-color: var(--bd-blue); + color: #fff; +} + +#bd-settings-sidebar .ui-tab-bar-header { + font-size: 12px; + font-weight: 700; + line-height: 16px; + text-transform: uppercase; + text-overflow: ellipsis; + white-space: nowrap; + flex-shrink: 0; + padding: 6px 10px; + overflow: hidden; + + display: flex; + justify-content: space-between; +} +.theme-dark #bd-settings-sidebar .ui-tab-bar-header { + color: #72767d; +} +.theme-light #bd-settings-sidebar .ui-tab-bar-header { + color: #b9bbbe; +} + +#bd-settings-sidebar .ui-tab-bar-header .bd-changelog-button { + height: 16px; +} + +#bd-settings-sidebar .ui-tab-bar-header .bd-icon { + cursor: pointer; + fill: #72767d; +} + +#bd-settings-sidebar .ui-tab-bar-header .bd-icon:hover { + fill: #fff; +} + +#bd-settings-sidebar .ui-tab-bar-separator { + height: 1px; + margin: 8px 10px; +} +.theme-dark #bd-settings-sidebar .ui-tab-bar-separator { + background-color: rgba(114,118,125,.3); +} +.theme-light #bd-settings-sidebar .ui-tab-bar-separator { + background-color: rgba(185,187,190,.3); +} + +.ui-flex { + display: flex; +} + +#bd-settingspane-container h2.ui-form-title { + font-size: 16px; + font-weight: 600; + line-height: 20px; + text-transform: uppercase; + display: inline-block; + margin-bottom: 20px; +} +.theme-dark #bd-settingspane-container h2.ui-form-title { + color: #f6f6f7; +} +.theme-light #bd-settingspane-container h2.ui-form-title { + color: #4f545c; +} + +#bd-settingspane-container .ui-switch-item { + flex-direction: column; + margin-top: 8px; +} + +#bd-settingspane-container .ui-switch-item h3 { + font-size: 16px; + font-weight: 500; + line-height: 24px; + flex: 1; +} +.theme-dark #bd-settingspane-container .ui-switch-item h3 { + color: #f6f6f7; +} +.theme-light #bd-settingspane-container .ui-switch-item h3 { + color: #4f545c; +} + +#bd-settingspane-container .ui-switch-item .style-description { + font-size: 14px; + font-weight: 500; + line-height: 20px; + margin-bottom: 10px; + padding-bottom: 10px; + border-bottom: 1px solid hsla(218,5%,47%,.3); +} +.theme-dark #bd-settingspane-container .ui-switch-item .style-description { + color: #72767d; +} +.theme-light #bd-settingspane-container .ui-switch-item .style-description { + color: rgba(114,118,125,.6); +} + +#bd-settingspane-container .ui-switch-item .ui-switch-wrapper { + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + position: relative; + width: 44px; + height: 24px; + display: block; + flex: 0 0 auto; +} + +#bd-settingspane-container .ui-switch-item .ui-switch-wrapper input { + position: absolute; + opacity: 0; + cursor: pointer; + width: 100%; + height: 100%; + z-index: 1; +} + +#bd-settingspane-container .ui-switch-item .ui-switch-wrapper .ui-switch { + background: var(--bd-blue); + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + background: #72767d; + border-radius: 14px; + transition: background .15s ease-in-out,box-shadow .15s ease-in-out,border .15s ease-in-out; +} + +#bd-settingspane-container .ui-switch-item .ui-switch-wrapper .ui-switch:before { + content: ""; + display: block; + width: 18px; + height: 18px; + position: absolute; + top: 3px; + left: 3px; + bottom: 3px; + background: #f6f6f7; + border-radius: 10px; + transition: all .15s ease; + box-shadow: 0 3px 1px 0 rgba(0,0,0,.05),0 2px 2px 0 rgba(0,0,0,.1),0 3px 3px 0 rgba(0,0,0,.05); +} + +#bd-settingspane-container .ui-switch-item .ui-switch-wrapper .ui-switch.checked { + background: var(--bd-blue); +} + +#bd-settingspane-container .ui-switch-item .ui-switch-wrapper .ui-switch.checked:before { + transform: translateX(20px); +} + +#bd-settingspane-container .scroller-wrap { + height: 100%; +} + +#bd-settingspane-container .scroller-wrap .scroller { + display: flex; +} +.content-column .ui-form-title:first-child { + margin-top: 0; +} +/* ================= */ +/* END BD SETTINGS */ + + + + + +/* BEGIN PLUGIN/THEME LIST */ +/* ======================= */ +.bd-reload { + cursor: pointer; + vertical-align: top; + fill: #dcddde; +} + +.bd-reload:hover { + fill: #fff; +} + +.bd-reload-header { + margin-left: 5px; +} + +.bd-reload-card { + margin-right: 5px; +} + +.bda-controls { + display: flex; +} + +.bd-addon-list { + user-select: text; +} + +.bd-addon-list .bd-addon-card { + max-height: 175px; + margin-bottom: 20px; + padding: 5px 8px; + border: 1px solid transparent; + border-radius: 5px; + overflow: hidden; +} +.theme-dark .bd-addon-list .bd-addon-card { + background-color: rgba(32,34,37,.6); + color: #f6f6f7; + border-color: #202225; +} +.theme-light .bd-addon-list .bd-addon-card { + background-color: #f8f9f9; + color: #4f545c; + border-color: #dcddde; +} + +.bd-addon-list .bd-addon-card.settings-open { + max-height: 800px; + overflow-y: auto; +} + +.bd-addon-list .bda-header { + font-size: 12px; + font-weight: 700; + display: flex; + align-items: center; + justify-content: space-between; + padding-bottom: 5px; + border-bottom: 1px solid transparent; + overflow: hidden; +} +.theme-dark .bd-addon-list .bda-header { + color: #f6f6f7; + border-bottom-color: rgba(114,118,125,.3); +} +.theme-light .bd-addon-list .bda-header { + color: #4f545c; + border-bottom-color: rgba(185,187,190,.3); +} + +.bd-addon-list .bda-description { + word-break: break-word; + max-height: 100px; + margin: 5px 0; + padding: 5px 0; + overflow-y: auto; +} +.theme-dark .bd-addon-list .bda-description { + color: #b9bbbe; +} +.theme-light .bd-addon-list .bda-description { + color: #72767d; +} + +.bd-addon-list .scroller::-webkit-scrollbar-track-piece, +.bd-addon-list .scroller::-webkit-scrollbar-thumb { + border-radius:0 !important; + border-color:transparent; +} + +.bd-addon-list .bd-card-footer { + font-size: 12px; + font-weight: 700; + display: flex; + align-items: center; + justify-content: space-between; + padding-top: 5px; + border-top: 1px solid transparent; + overflow: hidden; +} +.theme-dark .bd-addon-list .bd-card-footer { + border-top-color: rgba(114,118,125,.3); +} +.theme-light .bd-addon-list .bd-card-footer { + border-top-color: rgba(185,187,190,.3); +} + +.bd-addon-list .bd-card-footer button { + background: var(--bd-blue); + color: #FFF; + border-radius: 5px; + display: block; + margin-left: auto; + padding: 2px 16px; + transition: opacity 250ms ease; +} + +.theme-dark .bd-addon-list .bd-card-footer { + border-top-color: rgba(114,118,125,.3); +} +.theme-light .bd-addon-list .bd-card-footer { + border-top-color: rgba(185,187,190,.3); +} + +.bd-addon-list .bd-card-footer button { + padding: 3px 16px; + transition: opacity 250ms ease; +} + +.bd-addon-list .bd-card-footer button:disabled { + opacity: 0.4; +} + +.bd-addon-list a { + color: var(--bd-blue); +} + +.bd-addon-list a:hover { + text-decoration: underline; +} +/* ======================= */ +/* END PLUGIN/THEME LIST */ + + + + +/* BEGIN MODALS */ +/* ============ */ +@keyframes bd-backdrop { + to { opacity: 0.85; } +} + +@keyframes bd-modal-wrapper { + to { transform: scale(1); opacity: 1; } +} + +@keyframes bd-backdrop-closing { + to { opacity: 0; } +} + +@keyframes bd-modal-wrapper-closing { + to { transform: scale(0.7); opacity: 0; } +} + +.bd-backdrop { + animation: bd-backdrop 250ms ease; + animation-fill-mode: forwards; + opacity: 0; + background-color: rgb(0, 0, 0); + transform: translateZ(0px); +} + +.bd-modal-wrapper.closing .bd-backdrop { + animation: bd-backdrop-closing 200ms linear; + animation-fill-mode: forwards; + animation-delay: 50ms; + opacity: 0.85; +} + +.bd-modal-wrapper.closing .bd-modal { + animation: bd-modal-wrapper-closing 250ms cubic-bezier(0.19, 1, 0.22, 1); + animation-fill-mode: forwards; + opacity: 1; + transform: scale(1); +} + +.bd-modal-wrapper .bd-modal { + animation: bd-modal-wrapper 250ms cubic-bezier(0.175, 0.885, 0.32, 1.275); + animation-fill-mode: forwards; + transform: scale(0.7); + transform-origin: 50% 50%; + display: flex; + align-items: center; + box-sizing: border-box; + contain: content; + justify-content: center; + top: 0; + left: 0; + bottom: 0; + right: 0; + opacity: 0; + pointer-events: none; + position: absolute; + z-index: 1000; +} + +.bd-modal-wrapper .bd-modal-inner { + display: flex; + contain: layout; + flex-direction: column; + pointer-events: auto; + border: 1px solid rgba(28,36,43,.6); + border-radius: 5px; + box-shadow: 0 2px 10px 0 rgba(0,0,0,.2); + overflow: hidden; + max-height: 660px; + min-height: 200px; + width: 440px; + user-select: text; +} + +.bd-modal-wrapper .bd-content-modal .bd-modal-inner { + height: 500px; + width: 700px; +} + +.bd-modal-wrapper .header { + background-color: #35393e; + box-shadow: 0 2px 3px 0 rgba(0,0,0,.2); + padding: 12px 20px; + z-index: 1; + color: #fff; + font-size: 16px; + font-weight: 700; + line-height: 19px; +} + +.bd-modal-wrapper .bd-modal-body { + background-color: #36393f; + color: #fff; + flex-direction: row; + overflow: hidden; + display: flex; + flex-direction: column; + flex: 1; + contain: layout; + position: relative; +} + +.bd-modal-wrapper .scroller { + padding: 10px; +} + +.bd-modal-wrapper .bd-content-modal .bd-modal-body { + padding: 0; +} + +.bd-modal-wrapper .scroller { + overflow-y: auto; +} + +.bd-modal-wrapper .footer { + display: flex; + justify-content: flex-end; + padding: 10px 20px; +} + +.bd-modal-wrapper .footer button { + background-color: var(--bd-blue); + color: #fff; + min-height: 32px; + min-width: 60px; + align-items: center; + border-radius: 3px; + display: flex; + font-size: 14px; + font-weight: 500; + justify-content: center; + line-height: 16px; + padding: 2px 16px; + user-select: none; +} + +.bd-modal-wrapper .footer button:hover { + background-color: #677bc4; +} + +.bd-modal-wrapper .footer button:active { + background-color: #5f6fb9; +} + +.bd-modal-wrapper .tab-bar-container { + align-items: center; + border-bottom: 0; + background: rgba(0,0,0, 0.2); + box-shadow: 0 2px 3px 0 rgba(0,0,0,.1); + display: flex; + flex-direction: row; + justify-content: space-between; + margin-bottom: 15px; +} + +.bd-modal-wrapper .tab-bar.TOP { + margin: 0; + border: 0; + display: flex; + flex-direction: row; + justify-content: space-between; + align-items: center; +} + +.bd-modal-wrapper .tab-bar-container .tab-bar-item { + margin: 0 15px; + padding: 15px 0; + color: #fff !important; + opacity: 0.5; + transition: opacity 200ms ease; + border-bottom: 2px solid transparent; +} + +.bd-modal-wrapper .tab-bar-container .tab-bar-item:hover { + border-color: #fff; + cursor: pointer; +} + +.bd-modal-wrapper .tab-bar-container .tab-bar-item.selected { + opacity: 1; + border-color: #fff; +} + +.bd-modal-wrapper .tab-bar.TOP .tab-bar-item+.tab-bar-item { + margin: 0; +} + +.bd-modal-wrapper .table-header { + display: flex; + justify-content: space-between; + color: #fff; + font-weight: 700; + padding-bottom: 10px; + margin: 3px 15px 0 15px; + border-bottom: 1px solid #fff; + font-size: 14px; +} + +.bd-modal-wrapper .table-column { + width: 25%; +} + +.bd-modal-wrapper .table-column.column-error { + width: 50%; +} + +.bd-modal-wrapper .table-column { + word-wrap: break-word; +} + +.bd-modal-wrapper .errors { + display: flex; + flex-direction: column; + padding: 0; + font-size: 14px; + padding: 0 5px; +} + +.bd-modal-wrapper .error { + display: flex; + color: #fff; + border-bottom: 1px solid rgba(255,255,255, 0.25); + padding: 15px 0; + align-items: center; +} + +.bd-modal-wrapper .bd-content-modal .scroller { + padding-top: 0; +} +/* ============ */ +/* END MODALS */ + + + +/* BEGIN TOASTS */ +/* ============ */ +.bd-toasts { + position: fixed; + display: flex; + top: 0; + flex-direction: column; + align-items: center; + justify-content: flex-end; + pointer-events: none; + z-index: 4000; +} + +@keyframes bd-toast-up { + from { + transform: translateY(0); + opacity: 0; + } +} + +.bd-toast { + animation: bd-toast-up 300ms ease; + transform: translateY(-10px); + background: #36393F; + padding: 10px; + border-radius: 5px; + box-shadow: 0 0 0 1px rgba(32,34,37,.6), 0 2px 10px 0 rgba(0,0,0,.2); + font-weight: 500; + color: #fff; + user-select: text; + font-size: 14px; + opacity: 1; + margin-top: 10px; + pointer-events: none; + user-select: none; +} + +@keyframes bd-toast-down { + to { + transform: translateY(0px); + opacity: 0; + } +} + +.bd-toast.closing { + animation: bd-toast-down 200ms ease; + animation-fill-mode: forwards; + opacity: 1; + transform: translateY(-10px); +} + + +.bd-toast.icon { + padding-left: 30px; + background-size: 20px 20px; + background-repeat: no-repeat; + background-position: 6px 50%; +} + +.bd-toast.toast-info { + background-color: #4a90e2; +} + +.bd-toast.toast-info.icon { + background-image: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSIjRkZGRkZGIiBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4gICAgPHBhdGggZD0iTTAgMGgyNHYyNEgweiIgZmlsbD0ibm9uZSIvPiAgICA8cGF0aCBkPSJNMTIgMkM2LjQ4IDIgMiA2LjQ4IDIgMTJzNC40OCAxMCAxMCAxMCAxMC00LjQ4IDEwLTEwUzE3LjUyIDIgMTIgMnptMSAxNWgtMnYtNmgydjZ6bTAtOGgtMlY3aDJ2MnoiLz48L3N2Zz4=); +} + +.bd-toast.toast-success { + background-color: #43b581; +} + +.bd-toast.toast-success.icon { + background-image: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSIjRkZGRkZGIiBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4gICAgPHBhdGggZD0iTTAgMGgyNHYyNEgweiIgZmlsbD0ibm9uZSIvPiAgICA8cGF0aCBkPSJNMTIgMkM2LjQ4IDIgMiA2LjQ4IDIgMTJzNC40OCAxMCAxMCAxMCAxMC00LjQ4IDEwLTEwUzE3LjUyIDIgMTIgMnptLTIgMTVsLTUtNSAxLjQxLTEuNDFMMTAgMTQuMTdsNy41OS03LjU5TDE5IDhsLTkgOXoiLz48L3N2Zz4=); +} +.bd-toast.toast-danger, +.bd-toast.toast-error { + background-color: #f04747; +} + +.bd-toast.toast-danger.icon, +.bd-toast.toast-error.icon { + background-image: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSIjRkZGRkZGIiBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4gICAgPHBhdGggZD0iTTEyIDJDNi40NyAyIDIgNi40NyAyIDEyczQuNDcgMTAgMTAgMTAgMTAtNC40NyAxMC0xMFMxNy41MyAyIDEyIDJ6bTUgMTMuNTlMMTUuNTkgMTcgMTIgMTMuNDEgOC40MSAxNyA3IDE1LjU5IDEwLjU5IDEyIDcgOC40MSA4LjQxIDcgMTIgMTAuNTkgMTUuNTkgNyAxNyA4LjQxIDEzLjQxIDEyIDE3IDE1LjU5eiIvPiAgICA8cGF0aCBkPSJNMCAwaDI0djI0SDB6IiBmaWxsPSJub25lIi8+PC9zdmc+); +} + +.bd-toast.toast-warning, +.bd-toast.toast-warn { + background-color: #FFA600; + color: white; +} + +.bd-toast.toast-warning.icon, +.bd-toast.toast-warn.icon { + background-image: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSIjRkZGRkZGIiBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4gICAgPHBhdGggZD0iTTAgMGgyNHYyNEgweiIgZmlsbD0ibm9uZSIvPiAgICA8cGF0aCBkPSJNMSAyMWgyMkwxMiAyIDEgMjF6bTEyLTNoLTJ2LTJoMnYyem0wLTRoLTJ2LTRoMnY0eiIvPjwvc3ZnPg==); +} +/* ============ */ +/* END TOASTS */ + + + + + + +/* BEGIN MINIMAL MODE */ +/* ================== */ + +/* Messages */ +/* message divider */ +.bd-minimal .divider-32i8lo {opacity: 0;} + +/* message avatars */ +.bd-minimal .large-3ChYtB { + max-width: 20px; + max-height: 20px; + background-size: 100%; + margin-right: 2px; + margin-top: 0; + border-radius: 0; +} + +/* message content */ +.bd-minimal .content-3dzVd8 { + border-left: 2px solid #EBEBEB; + padding-left: 2px; +} +.bd-minimal .theme-dark .content-3dzVd8 { + border-left: 2px solid #303030; +} + +/* message username */ +.bd-minimal .username-_4ZSMR { + font-size: small; +} + +/* message group */ +.bd-minimal .container-1YxwTf { + padding: 5px; +} + +/* message embed */ +.bd-minimal .embed-IeVjo6 { + padding: 2px; +} + +/* Member List */ +/* member list wrap */ +.bd-minimal .membersWrap-2h-GB4 { + min-width: 0px; +} + +/* member list avatars */ +.bd-minimal .members-1998pB .small-5Os1Bb { + max-width: 15px; + max-height: 15px; + background-size: 15px 15px; +} + +/* member list avatars */ +.bd-minimal .members-1998pB .small-5Os1Bb .status-oxiHuE { + height: 5px; + width: 5px; +} + +/* member list list item */ +.bd-minimal .members-1998pB .member-3W1lQa { + padding: 5px; +} + +/* member list item inner */ +.bd-minimal .members-1998pB .memberInner-2CPc3V { + transform: scale(0.9); +} + +/* member list role label */ +.bd-minimal .members-1998pB .membersGroup-v9BXpm { + margin-top: 3px; + transform: scale(0.9); +} + + +/* Channel List */ +/* Hide Channel Mode */ +.bd-minimal.bd-minimal-chan .channels-Ie2l6A { + display: none; +} + +/* channel list guild name */ +.bd-minimal .channels-Ie2l6A header span { + font-size: 12px; +} + +/* channel list */ +.bd-minimal .channels-Ie2l6A { + width: 160px; +} + +/* channel item */ +.bd-minimal .containerDefault-3GGEv_ { + transform: scale(0.9); +} + +/* channel name */ +.bd-minimal .content-3at_AU { + transform: scale(0.9); +} + +/* channel icon */ +.bd-minimal .icon-1_QxNX { + width: 14px; + height: 14px; +} + + +/* Guild List */ +/* guild */ +.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .listItem-2P_4kh { + width: 20px; + height: 20px; + background-size: 100%; + font-size: 15px; + line-height: 20px; + margin: 0 12.5px 8px; +} + +/* guild link and icon */ +.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .wrapper-25eVIn a, +.bd-minimal .listItem-2P_4kh .wrapper-25eVIn .icon-27yU2q { + width: 20px; + height: 20px; + background-size: 100%; + font-size: 15px; + line-height: 20px; +} + +/* guild inner */ +.bd-minimal .listItem-2P_4kh .wrapper-25eVIn { + width: 20px; + height: 20px; + background-size: 100%; + font-size: 15px; + line-height: 20px; +} +.bd-minimal .listItem-2P_4kh svg, +.bd-minimal .listItem-2P_4kh foreignObject[mask] { + mask: none; +} + +/* home icon */ +.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .homeIcon-tEMBK1 { + width: 10px; + height: 10px; + background-size: 100%; + font-size: 15px; + line-height: 20px; +} + +/* add and search */ +.bd-minimal .circleIconButton-jET_ig { + height: 20px; + width: 20px; +} + +.bd-minimal .circleIconButton-jET_ig svg { + height: 14px; + width: 14px; +} + +/* friends online */ +.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .friendsOnline-_wi_fM { + margin-left: -15px; + font-size: 7px; +} + +/* public servers button */ +.bd-minimal #bd-pub-li { + height: 16px; +} +.bd-minimal #bd-pub-button { + font-size: 8px; + line-height: 16px; + height: 16px; +} + +/* guild list */ +.bd-minimal .wrapper-1Rf91z, +.bd-minimal .wrapper-1Rf91z .scrollerWrap-1IAIlv, +.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG { + width: 45px; +} + +/* separator */ +.bd-minimal .wrapper-1Rf91z .guildSeparator-3s64Iy { + margin-left: -15px; +} + +/* unread icon */ +.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .listItem-2P_4kh .wrapper-sa6paO { + height: 20px; + margin-top: 0px; + margin-left: -12.5px; +} + +/* audio/video */ +.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .iconBadge-2wi9r4 { + width: 12px; + height: 12px; + background-size: 12px; +} + + +/* Account Container */ +/* avatar */ +.bd-minimal .container-2Thooq .avatarSmall-3ACRaI { + width: 15px; + height: 15px; + background-size: 15px 15px; +} + +/* status */ +.bd-minimal .container-2Thooq .avatarSmall-3ACRaI .status-oxiHuE { + height: 5px; + width: 5px; +} + +/* username and discrim */ +.bd-minimal .container-2Thooq .accountDetails-3k9g4n { + transform: scale(0.8); +} + +/* 3 buttons */ +.bd-minimal .container-2Thooq .button-2b6hmh { + height: 14px; + width: 14px; + background-size: 14px 14px; + margin-left: 3px; +} + +/* 3 buttons icons */ +.bd-minimal .container-2Thooq .button-2b6hmh svg { + height: 14px; + width: 14px; +} +/* ================== */ +/* END MINIMAL MODE */ + + + +/* BEGIN DARK MODE */ +/* =============== */ + +/* add/create server */ +.bda-dark .theme-dark .root-1gCeng, +.bda-dark .theme-dark .theme-light .slide-2pHaq5 { + background: #36393f; +} + +.bda-dark .root-1gCeng .input-1mgnkM { + color: #e3e5e8; + border-bottom-color: #292b2f; +} + +.bda-dark .theme-dark .theme-dark .action-1lSjCi, +.bda-dark .theme-dark .theme-light .action-1lSjCi { + background: #2F3136; +} + +.bda-dark .theme-dark .theme-light .footer-3rDWdC { + background: #2f3136; + box-shadow: none; +} + +/* centered or */ +.bda-dark .theme-dark .theme-dark .or-3THJsp, +.bda-dark .theme-dark .theme-light .or-3THJsp { + background: #2F3136; + order: 2; + height: 56px; + width: 56px; + top: 103px; + line-height: 56px; + left: calc(50% - 29px); + border-radius: 50%; + border: 2px solid #484B52; +} + +.bda-dark .theme-dark .create-3jownz { + order: 1; +} + +.bda-dark .theme-dark .join-33Tr-7 { + order: 3; +} + +.bda-dark .theme-dark .theme-dark .actionIcon-2IISM_, +.bda-dark .theme-dark .theme-light .actionIcon-2IISM_ { + filter: grayscale(100%) brightness(60%); +} + +.bda-dark .theme-dark .theme-light .footer-2yfCgX { + background: #2F3136; +} + +/* Region Select */ +.bda-dark .theme-dark .regionSelectModal-12e-57 { + background: #36393f; +} + +.bda-dark .theme-dark .regionSelectModal-12e-57 .regionSelectModalOption-2DSIZ3 { + background: #2F3136; + border: 2px solid #484B52; +} + + +/* =============== */ +/* END DARK MODE */ + + + +.bd-switch { + background-color: #72767d; + border-radius: 14px; + width: 42px; + height: 24px; + opacity: 1; + overflow: hidden; + user-select: none; + position: relative; + display: block; + flex: 0 0 auto; + transition: background .15s ease-in-out,box-shadow .15s ease-in-out,border .15s ease-in-out,opacity .15s ease-in-out; + margin-left: 10px; + box-shadow: inset 0 1px 1px rgba(0,0,0,.15); +} + +.bd-switch::before { + content: ""; + display: block; + position: absolute; + top: 0; + left: 0; + bottom: 0; + right: 0; + z-index: 0; + opacity: 0; + background-color: #000; +} + +.bd-switch::after { + content: ""; + display: block; + position: absolute; + background-color: #fff; + z-index: 1; + width: 18px; + margin: 3px; + border-radius: 9px; + height: 18px; + left: 0; + transition: transform .15s ease-in-out,width .1s ease-in-out,left .1s ease-in-out; + box-shadow: 0 2px 4px rgba(0,0,0,.3); +} + +.bd-switch .bd-checkbox { + position: absolute; + width: 100%; + height: 100%; + opacity: 0; + padding: 0; + margin: 0; + z-index: 2; + cursor: pointer; +} + +.bd-switch-checked { + background-color: var(--bd-blue); +} + +.bd-switch-checked::after { + transform: translate3d(18px,0,0); +} + +.bd-switch-disabled { + opacity: .3; + cursor: not-allowed; +} + + + + + + + + + + + +.bd-addon-button { + cursor: pointer; +} + +.bd-addon-button + .bd-addon-button { + margin-left: 5px; +} + + +.bd-addon-controls { + display: flex; + align-items: center; + justify-content: space-between; +} + +.bd-addon-controls .bd-search { + font-size: 13px; + margin: 0; + width: 200px; +} + +.bd-addon-dropdowns { + display: flex; +} + +.bd-select-wrapper + .bd-select-wrapper { + margin-left: 10px; +} + +.bd-select-wrapper { + color: #f6f6f7; + font-size: 13px; + display: flex; + align-items: center; +} + +.bd-select-wrapper label { + opacity: .3; + margin-right: 5px; +} + +.bd-select { + position: relative; + cursor: pointer; + color: #f6f6f7; + font-size: 13px; + display: flex; + align-items: center; + justify-content: space-between; + background-color: rgba(0, 0, 0, 0.1); + border: 1px solid rgba(0, 0, 0, 0.3); + border-radius: 3px; + padding: 5px 5px 5px 0; +} + +.bd-select.bd-select-transparent { + background: none; + border: none; + padding: 0; +} + +.bd-select-value { + padding-left: 12px; +} + +.bd-select-arrow { + margin-left: 10px; +} + +.bd-select .bd-select-options { + position: absolute; + background: #2F3136; + border-radius: 0 0 3px 3px; + max-height: 300px; + min-width: calc(100% + 2px); + overflow-y: auto; + box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 5px 0px; + border: 1px solid rgba(0, 0, 0, 0.3); + border-top: 0; + margin-top: -1px; + margin-left: -1px; + z-index: 3; + top: 100%; +} + +.bd-select-transparent .bd-select-options { + border: 1px solid rgba(0, 0, 0, 0.3); + margin-top: 3px; + border-radius: 3px; +} + +.bd-select .bd-select-option { + padding: 8px 12px; + cursor: pointer; + white-space: pre; +} + +.bd-select .bd-select-option:hover, +.bd-select .bd-select-option.selected { + background: #26272B; +} + + + + +.bd-search-wrapper { + padding: 3px; + border-radius: 3px; + outline: none; + border: 0; + background-color: #202225; + color: #fff; + display: flex; + align-items: center; +} + +.bd-search { + padding: 2px 3px; + background: none; + border: 0; + color: #fff; + flex: 1; +} + +.bd-search-wrapper > svg { + margin-right: 2px; +} + + +.bd-chat-badge { + vertical-align: bottom; + line-height: 1.375rem; + display: inline-block; + height: 21px; +} + +.compact-T3H92H .bd-chat-badge { + position: absolute; + left: 5px; + top: 4px; + width: 16px; + display: inline-flex; + +} + +.bd-member-badge { + height: 15px; + margin-left: 4px; +} \ No newline at end of file diff --git a/BetterDiscordApp/css/main.min.css b/BetterDiscordApp/css/main.min.css new file mode 100644 index 0000000..9eb652a --- /dev/null +++ b/BetterDiscordApp/css/main.min.css @@ -0,0 +1 @@ +:root{--bd-blue: #3E82E5;--bd-blue-hover: rgb(56,117,206);--bd-blue-active: rgb(50,104,183);--blurple: #7289DA}.bd-loaderv2{background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+IDwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+PHN2ZyBoZWlnaHQ9IjEwMCUiIHN0eWxlPSJmaWxsLXJ1bGU6ZXZlbm9kZDtjbGlwLXJ1bGU6ZXZlbm9kZDtzdHJva2UtbGluZWNhcDpyb3VuZDtzdHJva2UtbGluZWpvaW46cm91bmQ7IiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWw6c3BhY2U9InByZXNlcnZlIiB3aWR0aD0iMTAwJSIgdmVyc2lvbj0iMS4xIiB2aWV3Qm94PSIwIDAgMjAwMCAyMDAwIj4gICAgPG1ldGFkYXRhIC8+ICAgIDxkZWZzPiAgICAgICAgPGZpbHRlciBpZD0ic2hhZG93MSI+ICAgICAgICA8ZmVEcm9wU2hhZG93IGR4PSIyMCIgZHk9IjAiIHN0ZERldmlhdGlvbj0iMjAiIGZsb29kLWNvbG9yPSJyZ2JhKDAsMCwwLDAuMzUpIi8+ICAgICAgICA8L2ZpbHRlcj4gICAgICAgIDxmaWx0ZXIgaWQ9InNoYWRvdzIiPiAgICAgICAgPGZlRHJvcFNoYWRvdyBkeD0iMTUiIGR5PSIwIiBzdGREZXZpYXRpb249IjIwIiBmbG9vZC1jb2xvcj0icmdiYSgyNTUsMjU1LDI1NSwwLjE1KSIvPiAgICAgICAgPC9maWx0ZXI+ICAgICAgICA8ZmlsdGVyIGlkPSJzaGFkb3czIj4gICAgICAgIDxmZURyb3BTaGFkb3cgZHg9IjEwIiBkeT0iMCIgc3RkRGV2aWF0aW9uPSIyMCIgZmxvb2QtY29sb3I9InJnYmEoMCwwLDAsMC4zNSkiLz4gICAgICAgIDwvZmlsdGVyPiAgICA8L2RlZnM+ICAgIDxnPiAgICAgICAgPHBhdGggc3R5bGU9ImZpbHRlcjogdXJsKCNzaGFkb3czKSIgZD0iTTExOTUuNDQrMTM1LjQ0MkwxMTk1LjQ0KzEzNS40NDJMOTk3LjYrMTM2LjQ0MkMxMDI0LjIrMTQ5Ljc0MisxMTcwLjM0KzE2My41NDIrMTE5My42NCsxNzkuNzQyQzEyNjQuMzQrMjI4Ljg0MisxMzE5Ljc0KzI5MS4yNDIrMTM1OC4yNCszNjUuMDQyQzEzOTguMTQrNDQxLjY0MisxNDE5Ljc0KzUzMC42NDIrMTQyMi41NCs2MjkuNjQyTDE0MjIuNTQrNjMwLjg0MkwxNDIyLjU0KzYzMi4wNDJDMTQyMi41NCs3NzMuMTQyKzE0MjIuNTQrMTIyOC4xNCsxNDIyLjU0KzEzNjkuMTRMMTQyMi41NCsxMzcwLjM0TDE0MjIuNTQrMTM3MS41NEMxNDE5Ljg0KzE0NzAuNTQrMTM5OC4yNCsxNTU5LjU0KzEzNTguMjQrMTYzNi4xNEMxMzE5Ljc0KzE3MDkuOTQrMTI2NC40NCsxNzcyLjM0KzExOTMuNjQrMTgyMS40NEMxMTcxLjA0KzE4MzcuMTQrMTAyNS43KzE4NTAuNTQrMTAwMCsxODYzLjU0TDExOTMuNTQrMTg2NC41NEMxNTM5Ljc0KzE4NjYuNDQrMTg2NC41NCsxNjkzLjM0KzE4NjQuNTQrMTI5Ni42NEwxODY0LjU0KzcxNi45NDJDMTg2Ni40NCszMTIuNDQyKzE1NDEuNjQrMTM1LjQ0MisxMTk1LjQ0KzEzNS40NDJaIiBmaWxsPSIjMTcxNzE3IiBvcGFjaXR5PSIxIi8+ICAgICAgICA8cGF0aCBzdHlsZT0iZmlsdGVyOiB1cmwoI3NoYWRvdzIpIiBkPSJNMTY5NS41NCs2MzEuNDQyQzE2ODUuODQrMjc4LjA0MisxNDA5LjM0KzEzNS40NDIrMTA1Mi45NCsxMzUuNDQyTDM2MS43NCsxMzYuNDQyTDgwMy43NCs0OTAuNDQyTDEwNjAuNzQrNDkwLjQ0MkMxMzM1LjI0KzQ5MC40NDIrMTMzNS4yNCs4MzUuMzQyKzEwNjAuNzQrODM1LjM0MkwxMDYwLjc0KzExNjQuODRDMTE1MC4yMisxMTY0Ljg0KzEyMTAuNTMrMTIwMS40OCsxMjQxLjY4KzEyNTAuODdDMTMwNi4wNysxMzUzKzEyNDUuNzYrMTUwOS42NCsxMDYwLjc0KzE1MDkuNjRMMzYxLjc0KzE4NjMuNTRMMTA1Mi45NCsxODY0LjU0QzE0MDkuMjQrMTg2NC41NCsxNjg1Ljc0KzE3MjEuOTQrMTY5NS41NCsxMzY4LjU0QzE2OTUuNTQrMTIwNS45NCsxNjUxLjA0KzEwODQuNDQrMTU3Mi42NCs5OTkuOTQyQzE2NTEuMDQrOTE1LjU0MisxNjk1LjU0Kzc5NC4wNDIrMTY5NS41NCs2MzEuNDQyWiIgZmlsbD0iIzNFODJFNSIgb3BhY2l0eT0iMSIvPiAgICAgICAgPHBhdGggc3R5bGU9ImZpbHRlcjogdXJsKCNzaGFkb3cxKSIgZD0iTTE0NjkuMjUrNjMxLjQ0MkMxNDU5LjU1KzI3OC4wNDIrMTE4My4wNSsxMzUuNDQyKzgyNi42NSsxMzUuNDQyTDEzNS40NSsxMzUuNDQyTDEzNS40NSsxMDA0QzEzNS40NSsxMDA0KzEzNS40MjcrMTI1NS4yMSszNTUuNjI2KzEyNTUuMjFDNTc1LjgyNSsxMjU1LjIxKzU3NS44NDgrMTAwNCs1NzUuODQ4KzEwMDRMNTc3LjQ1KzQ5MC40NDJMODM0LjQ1KzQ5MC40NDJDMTEwOC45NSs0OTAuNDQyKzExMDguOTUrODM1LjM0Mis4MzQuNDUrODM1LjM0Mkw2NjQuNjUrODM1LjM0Mkw2NjQuNjUrMTE2NC44NEw4MzQuNDUrMTE2NC44NEM5MjMuOTMyKzExNjQuODQrOTg0LjI0NCsxMjAxLjQ4KzEwMTUuMzkrMTI1MC44N0MxMDc5Ljc4KzEzNTMrMTAxOS40NysxNTA5LjY0KzgzNC40NSsxNTA5LjY0TDEzNS40NSsxNTA5LjY0TDEzNS40NSsxODY0LjU0TDgyNi42NSsxODY0LjU0QzExODIuOTUrMTg2NC41NCsxNDU5LjQ1KzE3MjEuOTQrMTQ2OS4yNSsxMzY4LjU0QzE0NjkuMjUrMTIwNS45NCsxNDI0Ljc1KzEwODQuNDQrMTM0Ni4zNSs5OTkuOTQyQzE0MjQuNzUrOTE1LjU0MisxNDY5LjI1Kzc5NC4wNDIrMTQ2OS4yNSs2MzEuNDQyWiIgZmlsbD0iI0ZGRkZGRiIgb3BhY2l0eT0iMSIvPiAgICA8L2c+PC9zdmc+)}.bd-loaderv2{position:fixed;bottom:5px;right:5px;z-index:2147483647;display:block;width:20px;height:20px;background-size:100% 100%;animation:bd-loaderv2-animation 1.5s ease-in-out infinite}@keyframes bd-loaderv2-animation{0%{opacity:.05}50%{opacity:.6}to{opacity:.05}}.bd-button{background-color:var(--bd-blue);color:#fff;border-radius:3px;padding:2px 6px}.bd-button:hover{background-color:var(--bd-blue-hover)}.bd-button:active{background-color:var(--bd-blue-active)}.bd-button.bd-button-success{background-color:#3ac15c}.bd-button.bd-button-success:hover{background-color:#34ae53}.bd-button.bd-button-success:active{background-color:#2e9a4a}.bd-button+.bd-button{margin-left:5px}.bd-button-outline{background-color:transparent;border:2px solid #fff}#emote-container{padding:10px}.emote-container{display:inline-block;padding:2px;border-radius:5px;width:30px;height:30px;position:relative}.emote-icon{max-width:100%;max-height:100%;position:absolute;margin:auto;top:0;right:0;bottom:0;left:0;cursor:pointer}.emote.stop-animation{animation:none!important}.emote-container:hover{background:rgba(123,123,123,.37)}.emoteflip,.emotespinflip{transform:scaleX(-1)}.emotespin{animation:1s emote-spin infinite linear}.emote1spin{animation:1s emote-spin-reverse infinite linear}.emotespin2{animation:.5s emote-spin infinite linear}.emote2spin{animation:.5s emote-spin-reverse infinite linear}.emotespin3{animation:.2s emote-spin infinite linear}.emote3spin{animation:.2s emote-spin-reverse infinite linear}.emotepulse{animation:1s emote-pulse infinite linear}.emotetr{transform:translateX(-3px)}.emotebl{transform:translateY(-3px)}.emotebr{transform:translate(-3px,-3px)}.emoteshake{animation:1s emote-shake infinite linear}.emoteflap{transform:scaleY(-1)!important}.emoteshake2{animation:emote-shake2 .3s linear infinite}.emoteshake3{animation:emote-shake3 .1s linear infinite}@keyframes emote-shake2{25%{transform:translate(-1px,-1px)}50%{transform:translate(-1px,1px)}75%{transform:translate(1px,1px)}75%{transform:translate(1px,-1px)}}@keyframes emote-shake3{25%{transform:translate(-1px,-1px)}50%{transform:translate(-1px,1px)}75%{transform:translate(1px,1px)}75%{transform:translate(1px,-1px)}}@keyframes emote-spin{0%{transform:rotate(0deg)}to{transform:rotate(360deg)}}@keyframes emote-spin-reverse{0%{transform:rotate(0deg)}to{transform:rotate(-360deg)}}@keyframes emote-pulse{0%{-webkit-transform:scale(1,1)}50%{-webkit-transform:scale(1.2,1.2)}to{-webkit-transform:scale(1,1)}}@keyframes emote-shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-4px,0,0)}40%,60%{transform:translate3d(4px,0,0)}}#removemenu{width:auto;background:#505050;position:absolute;z-index:999999;display:none;box-shadow:0 0 2px #000;padding:2px;left:25px;display:block!important;cursor:pointer;color:#fff;position:fixed}#removemenu ul a{text-decoration:none;color:#fff;padding:3px}.emotewrapper{position:relative;display:inline-flex;object-fit:contain;margin:-.1em .05em -.2em .1em;vertical-align:top}.emotewrapper.jumboable{margin-bottom:0;margin-top:.2em;vertical-align:-.3em}.emote{height:1.45em}.emote.jumboable{height:2rem}.emotewrapper:hover .fav{display:block}.fav{display:none;position:absolute;width:15px;height:15px;right:-7px;background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAAAzFBMVEUAAABQUFBMTExLS0tNTU1MTExNTU1NTU1MTExMTExNTU1LS0tEREBEREBEREBEREBJSUhLS0tLS0tEREBNTU1NTU1NTU1EREArKyhNTU1NTU0AAABMTExKSklMTExNTU1NTU1NTU1KSkpMTExKSkhNTU1KSkpISEZNTU1LS0tAQDxOTk5KSkpLS0tNTU1MTExMTEx/f39MTExMTExLS0pLS0tMTExNTU1NTU1LS0pNTU1NTU1NTU1NTU1NTU1NTUxNTU1NTU1NTUxMTEzB8C/5AAAAOnRSTlMAI8X96oWAgYSF68QBAg0PMCb9BIuLgQUD4N0Bh0mKhZSOQ4gcrKscaW8QRE6fmJyjAshASceG7cIpqQOxTQAAALVJREFUGFddx6FOA0EYAOGZvd07Qm6vVCAAgUUgQEDfX/YZMAigqaFN7iC5tsmPqGPUN/AvUVeoEbGOCElJz08Uzeixqu4AqomVVSNngOVjTqDGZSl3UFtPGV2ot2zaq96YM9p5Ddzcf/nTTAlj+/sNtNu8OcwkIsbPBtrUfMQeEhGQmHbmGIFMwLPzu6UMIwBNgToshgq8Nr2ki+Oy7ebDHp70LRPWB6OZgfWLWei7fJonOOsPCGA9kVlssOoAAAAASUVORK5CYII=);border:0;background-size:100% 100%;background-repeat:no-repeat;background-color:#303030;border-radius:5px;top:-7px;cursor:pointer}.fav.active{background-color:#ff0}.emojiPicker-3m1S-j{box-shadow:none;border-top:none;border-radius:0 0 5px 5px}#bda-qem{border-radius:5px 5px 0 0;background:#2f3136;border-bottom:1px solid rgba(0,0,0,.1)!important;height:30px;display:flex;flex-direction:row;padding-right:1px!important}.theme-light #bda-qem{background:#f2f3f5}#bda-qem button{border-left:1px solid #202225;background:#2f3136;box-shadow:rgba(0,0,0,.1) 1px 0 0 0;flex-grow:1;color:#fff}.theme-light #bda-qem button{border-left:1px solid #efefef;background:0 0;box-shadow:#cecece 1px 0 0 0;color:#000}#bda-qem button:first-child{border-left-color:transparent}#bda-qem button:hover{background:rgba(79,84,92,.16)}.theme-light #bda-qem button:hover{background:#ececec}#bda-qem-twitch{border-radius:5px 0 0 0;order:2}#bda-qem-emojis{border-radius:0 5px 0 0;order:3}#bda-qem-favourite{order:3}#bda-qem button.active,#bda-qem button.active:hover{background-color:var(--bd-blue)}.theme-light #bda-qem button.active,.theme-light #bda-qem button.active:hover{color:#fff}#bda-qem-twitch-container,#bda-qem-favourite-container{width:384px;height:424px;background-color:#2f3136;border-radius:0 0 5px 5px}.theme-light #bda-qem-twitch-container,.theme-light #bda-qem-favourite-container{background-color:#f2f3f5}#bda-qem-twitch-container .scroller-wrap,#bda-qem-favourite-container .scroller-wrap{height:100%}.emote-menu-inner{padding:5px 0 0 15px}.bda-qme-hidden #bda-qem-emojis{display:none}#bd-pub-li{height:20px;margin-bottom:10px;overflow:hidden}#bd-pub-button{border-radius:4px;background-color:#2f3136;color:#b9bbbe;text-align:center;font-size:12px;line-height:20px;height:20px}.bd-server-card .bd-server-tags{flex:1 1 auto;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:0;line-height:24px;font-size:12px;color:#b9bbbe;font-weight:700;margin-right:10px}.ui-card.ui-card-primary.bd-server-card:first-child{margin-bottom:13px}.ui-card.ui-card-primary.bd-server-card:first-child:after{border:3px solid var(--bd-blue);content:"";display:block;position:absolute;left:0;right:0;margin-top:4px}.bd-server-card.bd-server-card-pinned{margin-bottom:15px}.bd-server-card.bd-server-card-pinned:after{background:#3a71c1;content:"";height:3px;width:100%;display:block;margin-top:7px;position:absolute;top:100%}.bd-server-description-container{color:#b9bbbe;min-height:65px;max-height:65px;border-top:1px solid #3f4146;border-bottom:1px solid #3f4146;padding-top:5px;font-size:13px}.bd-server-header{justify-content:space-between;font-weight:600}.bd-server-card{display:flex}.bd-server-content{padding:5px 10px;flex:1}.bd-server-image{min-width:115px;min-height:115px;max-width:115px;max-height:115px}.bd-server-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;padding-right:15px;max-width:330px;flex:1 1 50%}.bd-layer{-ms-flex-direction:column;-webkit-box-direction:normal;-webkit-box-orient:vertical;bottom:0;display:-webkit-box;display:-ms-flexbox;display:flex;flex-direction:column;left:0;position:absolute;right:0;top:0}#pubslayer .ui-tab-bar-item{color:#b9bbbe;padding-top:6px;padding-bottom:6px;margin-bottom:2px;padding:6px 10px;position:relative;font-size:16px;line-height:20px;border-radius:3px;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;flex-shrink:0;font-weight:500;cursor:pointer}#pubslayer .ui-tab-bar-item:hover{color:#f6f6f7;background-color:rgba(186,188,191,.1)}#pubslayer .ui-tab-bar-item.selected{color:#fff;background-color:var(--bd-blue)}#pubslayer .ui-tab-bar-header{color:#72767d;padding:6px 10px;font-size:12px;line-height:16px;text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;flex-shrink:0;font-weight:500}#pubslayer #bd-settings-sidebar .ui-tab-bar-separator{background-color:rgba(114,118,126,.3);margin-left:10px;margin-right:10px;height:1px;margin-bottom:8px;margin-top:8px}#pubslayer h2.ui-form-title{color:#f6f6f7;text-transform:uppercase;font-weight:600}#pubslayer h5.ui-form-title{color:#f6f6f7}#pubslayer button{background:var(--bd-blue);color:#fff;font-size:14px;font-weight:500;line-height:16px;padding:2px 16px;border:0;border-radius:3px;transition:background-color .17s ease}#pubslayer button:hover{background-color:#677bc4}#pubslayer input{color:#f6f6f7;background-color:rgba(0,0,0,.1);border-color:rgba(0,0,0,.3);padding:10px;height:30px;border-width:1px;border-style:solid;border-radius:3px;outline:0;transition:background-color .15s ease,border .15s ease}.standardSidebarView-3F1I7i #bd-customcss-attach-controls button,.bd-detached-css-editor #bd-customcss-attach-controls button{margin:0;width:100px;background:#31332b;color:#fff;height:26px;font-weight:600;margin-top:5px;border-radius:3px}.standardSidebarView-3F1I7i #bd-customcss-attach-controls button:hover,.bd-detached-css-editor #bd-customcss-attach-controls button:hover{background:#3b3e44}.contentRegion-3nDuYy #bd-customcss-attach-controls,#bd-customcss-detach-container #bd-customcss-attach-controls{background:#272822;color:#fff;border:0;box-shadow:0 1px 0 0 #2f3129 inset}.contentRegion-3nDuYy #bd-customcss-pane,.contentRegion-3nDuYy #bd-customcss-innerpane,#bd-customcss-detach-container #bd-customcss-pane,#bd-customcss-detach-container #bd-customcss-innerpane{min-height:calc(80vh - 165px)}.standardSidebarView-3F1I7i #editor-detached h3{color:#87909c;font-weight:600;font-size:22px}.standardSidebarView-3F1I7i #editor-detached button{margin:auto;margin-left:calc(50% - 100px);margin-top:20px;background:var(--bd-blue);color:#fff;font-weight:600;border-radius:5px;font-size:20px}.editor-wrapper{display:flex}.line-numbers,.ace_editor{line-height:normal;font-family:Consolas,monospace;box-sizing:border-box;height:calc(100vh - 250px);font-size:14px}.line-numbers{white-space:pre;color:gray;padding:10px 5px 0 5px;background:#24262a;overflow:hidden}.ace_editor{width:100%;background:#292b2f;outline:0;color:#fff;padding:10px;resize:none}#bd-customcss-detach-container .editor-wrapper,#bd-customcss-detach-container .line-numbers,#bd-customcss-detach-container .ace_editor{height:100%}.bd-detached-editor .app-2rEoOp{width:70%}.bd-detached-editor #bd-customcss-detach-container{display:block}#bd-customcss-detach-container{display:none;position:absolute;width:30%;top:0;right:0;bottom:0;background-color:#36393e}#bd-customcss-detach-editor{height:calc(100% - 87px)}#bd-customcss-detach-editor #bd-customcss-innerpane,#bd-customcss-detach-editor .CodeMirror{height:100%}#bd-customcss-detach-controls{background:#e8e8e8;border-top:1px solid #adadad;box-shadow:inset 0 1px 0 0 #fff;height:100%;padding:5px}#bd-customcss-detach-controls .checkbox-group li{margin-top:5px;display:inline-block}#bd-customcss-detach-controls button{width:90px;height:30px;margin-top:8px;background-color:#738bd7;color:#fff;font-size:19px}#bd-customcss-detach-controls-buttons{bottom:5px}#editor-detached{margin-top:50px}#editor-detached h3{text-align:center;font-size:30px}#editor-detached .btn{left:50%;margin-left:-100px;margin-top:10px;width:200px;height:60px}#bd-customcss-attach-controls{background:#e8e8e8;border:1px solid #fff;border-top:1px solid #adadad;box-shadow:inset 0 1px 0 0 #fff;height:100%;padding:5px}#bd-customcss-attach-controls .checkbox-group{margin-bottom:0}#bd-customcss-attach-controls .checkbox-group li{margin-top:5px;display:inline-block}#bd-customcss-attach-controls button{margin:0;width:100px}#bd-customcss-detach-container #bd-customcss-detach-controls-buttons button{width:90px;height:30px;margin-top:8px;background-color:#738bd7;color:#fff;font-size:19px}#ace_settingsmenu_container{background:rgba(0,0,0,.7)!important}body #ace_settingsmenu{padding-top:35px}body .ace_closeButton{position:absolute;top:8px;right:12px;z-index:10000;padding:0;cursor:pointer;background:0 0;border:0}body .ace_closeButton::before{content:"✖";color:#36393f}body .ace_closeButton:active{transform:translateY(2px)}.theme-dark div #ace_settingsmenu{color:#f6f6f7;background:#36393f;box-shadow:0 0 0 1px rgba(32,34,37,.6),0 2px 10px 0 rgba(0,0,0,.2)}.theme-dark div #ace_settingsmenu select,.theme-dark div #ace_settingsmenu input[type=text]{color:#f6f6f7;background:#2f3136;border:1px solid #484b52}.theme-dark div .ace_closeButton::before{color:#f6f6f7}#bd-customcss-attach-controls .help-text{margin-top:8px;margin-bottom:3px;font-size:14px}#bd-customcss-attach-controls .help-text .inline{background:#31332b;padding:.2em;margin:-.2em 0;border-radius:3px}.bd-social-logo{opacity:.6}.bd-social-link:hover .bd-social-logo{opacity:1}.standardSidebarView-3F1I7i .bd-versioninfo-wrapper{bottom:0;left:0;position:fixed;background:inherit;right:0;padding:5px}.standardSidebarView-3F1I7i .bd-versioninfo-wrapper span{color:#b9bbbe;font-weight:600;font-size:11px}.standardSidebarView-3F1I7i .bd-versioninfo-wrapper a{font-size:11px}.bd-pfbtn{background:var(--bd-blue);color:#fff;border-radius:5px;margin-left:10px}#bd-settings-sidebar .ui-tab-bar-item{font-size:16px;font-weight:500;line-height:20px;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;flex-shrink:0;padding:6px 10px;border-radius:3px;position:relative;overflow:hidden}#bd-settings-sidebar .ui-tab-bar-item.selected{cursor:default}.theme-dark #bd-settings-sidebar .ui-tab-bar-item{color:#b9bbbe}.theme-dark #bd-settings-sidebar .ui-tab-bar-item:hover{background-color:rgba(185,187,190,.1);color:#f6f6f7}.theme-dark #bd-settings-sidebar .ui-tab-bar-item.selected{background-color:var(--bd-blue);color:#fff}.theme-light #bd-settings-sidebar .ui-tab-bar-item{color:#72767d}.theme-light #bd-settings-sidebar .ui-tab-bar-item:hover{background-color:rgba(79,84,92,.1);color:#4f545c}.theme-light #bd-settings-sidebar .ui-tab-bar-item.selected{background-color:var(--bd-blue);color:#fff}#bd-settings-sidebar .ui-tab-bar-header{font-size:12px;font-weight:700;line-height:16px;text-transform:uppercase;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;padding:6px 10px;overflow:hidden;display:flex;justify-content:space-between}.theme-dark #bd-settings-sidebar .ui-tab-bar-header{color:#72767d}.theme-light #bd-settings-sidebar .ui-tab-bar-header{color:#b9bbbe}#bd-settings-sidebar .ui-tab-bar-header .bd-changelog-button{height:16px}#bd-settings-sidebar .ui-tab-bar-header .bd-icon{cursor:pointer;fill:#72767d}#bd-settings-sidebar .ui-tab-bar-header .bd-icon:hover{fill:#fff}#bd-settings-sidebar .ui-tab-bar-separator{height:1px;margin:8px 10px}.theme-dark #bd-settings-sidebar .ui-tab-bar-separator{background-color:rgba(114,118,125,.3)}.theme-light #bd-settings-sidebar .ui-tab-bar-separator{background-color:rgba(185,187,190,.3)}.ui-flex{display:flex}#bd-settingspane-container h2.ui-form-title{font-size:16px;font-weight:600;line-height:20px;text-transform:uppercase;display:inline-block;margin-bottom:20px}.theme-dark #bd-settingspane-container h2.ui-form-title{color:#f6f6f7}.theme-light #bd-settingspane-container h2.ui-form-title{color:#4f545c}#bd-settingspane-container .ui-switch-item{flex-direction:column;margin-top:8px}#bd-settingspane-container .ui-switch-item h3{font-size:16px;font-weight:500;line-height:24px;flex:1}.theme-dark #bd-settingspane-container .ui-switch-item h3{color:#f6f6f7}.theme-light #bd-settingspane-container .ui-switch-item h3{color:#4f545c}#bd-settingspane-container .ui-switch-item .style-description{font-size:14px;font-weight:500;line-height:20px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid rgba(114,118,126,.3)}.theme-dark #bd-settingspane-container .ui-switch-item .style-description{color:#72767d}.theme-light #bd-settingspane-container .ui-switch-item .style-description{color:rgba(114,118,125,.6)}#bd-settingspane-container .ui-switch-item .ui-switch-wrapper{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:relative;width:44px;height:24px;display:block;flex:0 0 auto}#bd-settingspane-container .ui-switch-item .ui-switch-wrapper input{position:absolute;opacity:0;cursor:pointer;width:100%;height:100%;z-index:1}#bd-settingspane-container .ui-switch-item .ui-switch-wrapper .ui-switch{background:var(--bd-blue);position:absolute;top:0;right:0;bottom:0;left:0;background:#72767d;border-radius:14px;transition:background .15s ease-in-out,box-shadow .15s ease-in-out,border .15s ease-in-out}#bd-settingspane-container .ui-switch-item .ui-switch-wrapper .ui-switch:before{content:"";display:block;width:18px;height:18px;position:absolute;top:3px;left:3px;bottom:3px;background:#f6f6f7;border-radius:10px;transition:all .15s ease;box-shadow:0 3px 1px 0 rgba(0,0,0,.05),0 2px 2px 0 rgba(0,0,0,.1),0 3px 3px 0 rgba(0,0,0,.05)}#bd-settingspane-container .ui-switch-item .ui-switch-wrapper .ui-switch.checked{background:var(--bd-blue)}#bd-settingspane-container .ui-switch-item .ui-switch-wrapper .ui-switch.checked:before{transform:translateX(20px)}#bd-settingspane-container .scroller-wrap{height:100%}#bd-settingspane-container .scroller-wrap .scroller{display:flex}.content-column .ui-form-title:first-child{margin-top:0}.bd-reload{cursor:pointer;vertical-align:top;fill:#dcddde}.bd-reload:hover{fill:#fff}.bd-reload-header{margin-left:5px}.bd-reload-card{margin-right:5px}.bda-controls{display:flex}.bd-addon-list{user-select:text}.bd-addon-list .bd-addon-card{max-height:175px;margin-bottom:20px;padding:5px 8px;border:1px solid transparent;border-radius:5px;overflow:hidden}.theme-dark .bd-addon-list .bd-addon-card{background-color:rgba(32,34,37,.6);color:#f6f6f7;border-color:#202225}.theme-light .bd-addon-list .bd-addon-card{background-color:#f8f9f9;color:#4f545c;border-color:#dcddde}.bd-addon-list .bd-addon-card.settings-open{max-height:800px;overflow-y:auto}.bd-addon-list .bda-header{font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:space-between;padding-bottom:5px;border-bottom:1px solid transparent;overflow:hidden}.theme-dark .bd-addon-list .bda-header{color:#f6f6f7;border-bottom-color:rgba(114,118,125,.3)}.theme-light .bd-addon-list .bda-header{color:#4f545c;border-bottom-color:rgba(185,187,190,.3)}.bd-addon-list .bda-description{word-break:break-word;max-height:100px;margin:5px 0;padding:5px 0;overflow-y:auto}.theme-dark .bd-addon-list .bda-description{color:#b9bbbe}.theme-light .bd-addon-list .bda-description{color:#72767d}.bd-addon-list .scroller::-webkit-scrollbar-track-piece,.bd-addon-list .scroller::-webkit-scrollbar-thumb{border-radius:0!important;border-color:transparent}.bd-addon-list .bd-card-footer{font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:space-between;padding-top:5px;border-top:1px solid transparent;overflow:hidden}.theme-dark .bd-addon-list .bd-card-footer{border-top-color:rgba(114,118,125,.3)}.theme-light .bd-addon-list .bd-card-footer{border-top-color:rgba(185,187,190,.3)}.bd-addon-list .bd-card-footer button{background:var(--bd-blue);color:#fff;border-radius:5px;display:block;margin-left:auto;padding:2px 16px;transition:opacity 250ms ease}.theme-dark .bd-addon-list .bd-card-footer{border-top-color:rgba(114,118,125,.3)}.theme-light .bd-addon-list .bd-card-footer{border-top-color:rgba(185,187,190,.3)}.bd-addon-list .bd-card-footer button{padding:3px 16px;transition:opacity 250ms ease}.bd-addon-list .bd-card-footer button:disabled{opacity:.4}.bd-addon-list a{color:var(--bd-blue)}.bd-addon-list a:hover{text-decoration:underline}@keyframes bd-backdrop{to{opacity:.85}}@keyframes bd-modal-wrapper{to{transform:scale(1);opacity:1}}@keyframes bd-backdrop-closing{to{opacity:0}}@keyframes bd-modal-wrapper-closing{to{transform:scale(.7);opacity:0}}.bd-backdrop{animation:bd-backdrop 250ms ease;animation-fill-mode:forwards;opacity:0;background-color:#000;transform:translateZ(0)}.bd-modal-wrapper.closing .bd-backdrop{animation:bd-backdrop-closing 200ms linear;animation-fill-mode:forwards;animation-delay:50ms;opacity:.85}.bd-modal-wrapper.closing .bd-modal{animation:bd-modal-wrapper-closing 250ms cubic-bezier(.19,1,.22,1);animation-fill-mode:forwards;opacity:1;transform:scale(1)}.bd-modal-wrapper .bd-modal{animation:bd-modal-wrapper 250ms cubic-bezier(.175,.885,.32,1.275);animation-fill-mode:forwards;transform:scale(.7);transform-origin:50% 50%;display:flex;align-items:center;box-sizing:border-box;contain:content;justify-content:center;top:0;left:0;bottom:0;right:0;opacity:0;pointer-events:none;position:absolute;z-index:1000}.bd-modal-wrapper .bd-modal-inner{display:flex;contain:layout;flex-direction:column;pointer-events:auto;border:1px solid rgba(28,36,43,.6);border-radius:5px;box-shadow:0 2px 10px 0 rgba(0,0,0,.2);overflow:hidden;max-height:660px;min-height:200px;width:440px;user-select:text}.bd-modal-wrapper .bd-content-modal .bd-modal-inner{height:500px;width:700px}.bd-modal-wrapper .header{background-color:#35393e;box-shadow:0 2px 3px 0 rgba(0,0,0,.2);padding:12px 20px;z-index:1;color:#fff;font-size:16px;font-weight:700;line-height:19px}.bd-modal-wrapper .bd-modal-body{background-color:#36393f;color:#fff;flex-direction:row;overflow:hidden;display:flex;flex-direction:column;flex:1;contain:layout;position:relative}.bd-modal-wrapper .scroller{padding:10px}.bd-modal-wrapper .bd-content-modal .bd-modal-body{padding:0}.bd-modal-wrapper .scroller{overflow-y:auto}.bd-modal-wrapper .footer{display:flex;justify-content:flex-end;padding:10px 20px}.bd-modal-wrapper .footer button{background-color:var(--bd-blue);color:#fff;min-height:32px;min-width:60px;align-items:center;border-radius:3px;display:flex;font-size:14px;font-weight:500;justify-content:center;line-height:16px;padding:2px 16px;user-select:none}.bd-modal-wrapper .footer button:hover{background-color:#677bc4}.bd-modal-wrapper .footer button:active{background-color:#5f6fb9}.bd-modal-wrapper .tab-bar-container{align-items:center;border-bottom:0;background:rgba(0,0,0,.2);box-shadow:0 2px 3px 0 rgba(0,0,0,.1);display:flex;flex-direction:row;justify-content:space-between;margin-bottom:15px}.bd-modal-wrapper .tab-bar.TOP{margin:0;border:0;display:flex;flex-direction:row;justify-content:space-between;align-items:center}.bd-modal-wrapper .tab-bar-container .tab-bar-item{margin:0 15px;padding:15px 0;color:#fff!important;opacity:.5;transition:opacity 200ms ease;border-bottom:2px solid transparent}.bd-modal-wrapper .tab-bar-container .tab-bar-item:hover{border-color:#fff;cursor:pointer}.bd-modal-wrapper .tab-bar-container .tab-bar-item.selected{opacity:1;border-color:#fff}.bd-modal-wrapper .tab-bar.TOP .tab-bar-item+.tab-bar-item{margin:0}.bd-modal-wrapper .table-header{display:flex;justify-content:space-between;color:#fff;font-weight:700;padding-bottom:10px;margin:3px 15px 0 15px;border-bottom:1px solid #fff;font-size:14px}.bd-modal-wrapper .table-column{width:25%}.bd-modal-wrapper .table-column.column-error{width:50%}.bd-modal-wrapper .table-column{word-wrap:break-word}.bd-modal-wrapper .errors{display:flex;flex-direction:column;padding:0;font-size:14px;padding:0 5px}.bd-modal-wrapper .error{display:flex;color:#fff;border-bottom:1px solid rgba(255,255,255,.25);padding:15px 0;align-items:center}.bd-modal-wrapper .bd-content-modal .scroller{padding-top:0}.bd-toasts{position:fixed;display:flex;top:0;flex-direction:column;align-items:center;justify-content:flex-end;pointer-events:none;z-index:4000}@keyframes bd-toast-up{0%{transform:translateY(0);opacity:0}}.bd-toast{animation:bd-toast-up 300ms ease;transform:translateY(-10px);background:#36393f;padding:10px;border-radius:5px;box-shadow:0 0 0 1px rgba(32,34,37,.6),0 2px 10px 0 rgba(0,0,0,.2);font-weight:500;color:#fff;user-select:text;font-size:14px;opacity:1;margin-top:10px;pointer-events:none;user-select:none}@keyframes bd-toast-down{to{transform:translateY(0);opacity:0}}.bd-toast.closing{animation:bd-toast-down 200ms ease;animation-fill-mode:forwards;opacity:1;transform:translateY(-10px)}.bd-toast.icon{padding-left:30px;background-size:20px 20px;background-repeat:no-repeat;background-position:6px 50%}.bd-toast.toast-info{background-color:#4a90e2}.bd-toast.toast-info.icon{background-image:url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSIjRkZGRkZGIiBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4gICAgPHBhdGggZD0iTTAgMGgyNHYyNEgweiIgZmlsbD0ibm9uZSIvPiAgICA8cGF0aCBkPSJNMTIgMkM2LjQ4IDIgMiA2LjQ4IDIgMTJzNC40OCAxMCAxMCAxMCAxMC00LjQ4IDEwLTEwUzE3LjUyIDIgMTIgMnptMSAxNWgtMnYtNmgydjZ6bTAtOGgtMlY3aDJ2MnoiLz48L3N2Zz4=)}.bd-toast.toast-success{background-color:#43b581}.bd-toast.toast-success.icon{background-image:url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSIjRkZGRkZGIiBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4gICAgPHBhdGggZD0iTTAgMGgyNHYyNEgweiIgZmlsbD0ibm9uZSIvPiAgICA8cGF0aCBkPSJNMTIgMkM2LjQ4IDIgMiA2LjQ4IDIgMTJzNC40OCAxMCAxMCAxMCAxMC00LjQ4IDEwLTEwUzE3LjUyIDIgMTIgMnptLTIgMTVsLTUtNSAxLjQxLTEuNDFMMTAgMTQuMTdsNy41OS03LjU5TDE5IDhsLTkgOXoiLz48L3N2Zz4=)}.bd-toast.toast-danger,.bd-toast.toast-error{background-color:#f04747}.bd-toast.toast-danger.icon,.bd-toast.toast-error.icon{background-image:url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSIjRkZGRkZGIiBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4gICAgPHBhdGggZD0iTTEyIDJDNi40NyAyIDIgNi40NyAyIDEyczQuNDcgMTAgMTAgMTAgMTAtNC40NyAxMC0xMFMxNy41MyAyIDEyIDJ6bTUgMTMuNTlMMTUuNTkgMTcgMTIgMTMuNDEgOC40MSAxNyA3IDE1LjU5IDEwLjU5IDEyIDcgOC40MSA4LjQxIDcgMTIgMTAuNTkgMTUuNTkgNyAxNyA4LjQxIDEzLjQxIDEyIDE3IDE1LjU5eiIvPiAgICA8cGF0aCBkPSJNMCAwaDI0djI0SDB6IiBmaWxsPSJub25lIi8+PC9zdmc+)}.bd-toast.toast-warning,.bd-toast.toast-warn{background-color:#ffa600;color:#fff}.bd-toast.toast-warning.icon,.bd-toast.toast-warn.icon{background-image:url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSIjRkZGRkZGIiBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4gICAgPHBhdGggZD0iTTAgMGgyNHYyNEgweiIgZmlsbD0ibm9uZSIvPiAgICA8cGF0aCBkPSJNMSAyMWgyMkwxMiAyIDEgMjF6bTEyLTNoLTJ2LTJoMnYyem0wLTRoLTJ2LTRoMnY0eiIvPjwvc3ZnPg==)}.bd-minimal .divider-32i8lo{opacity:0}.bd-minimal .large-3ChYtB{max-width:20px;max-height:20px;background-size:100%;margin-right:2px;margin-top:0;border-radius:0}.bd-minimal .content-3dzVd8{border-left:2px solid #ebebeb;padding-left:2px}.bd-minimal .theme-dark .content-3dzVd8{border-left:2px solid #303030}.bd-minimal .username-_4ZSMR{font-size:small}.bd-minimal .container-1YxwTf{padding:5px}.bd-minimal .embed-IeVjo6{padding:2px}.bd-minimal .membersWrap-2h-GB4{min-width:0}.bd-minimal .members-1998pB .small-5Os1Bb{max-width:15px;max-height:15px;background-size:15px 15px}.bd-minimal .members-1998pB .small-5Os1Bb .status-oxiHuE{height:5px;width:5px}.bd-minimal .members-1998pB .member-3W1lQa{padding:5px}.bd-minimal .members-1998pB .memberInner-2CPc3V{transform:scale(.9)}.bd-minimal .members-1998pB .membersGroup-v9BXpm{margin-top:3px;transform:scale(.9)}.bd-minimal.bd-minimal-chan .channels-Ie2l6A{display:none}.bd-minimal .channels-Ie2l6A header span{font-size:12px}.bd-minimal .channels-Ie2l6A{width:160px}.bd-minimal .containerDefault-3GGEv_{transform:scale(.9)}.bd-minimal .content-3at_AU{transform:scale(.9)}.bd-minimal .icon-1_QxNX{width:14px;height:14px}.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .listItem-2P_4kh{width:20px;height:20px;background-size:100%;font-size:15px;line-height:20px;margin:0 12.5px 8px}.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .wrapper-25eVIn a,.bd-minimal .listItem-2P_4kh .wrapper-25eVIn .icon-27yU2q{width:20px;height:20px;background-size:100%;font-size:15px;line-height:20px}.bd-minimal .listItem-2P_4kh .wrapper-25eVIn{width:20px;height:20px;background-size:100%;font-size:15px;line-height:20px}.bd-minimal .listItem-2P_4kh svg,.bd-minimal .listItem-2P_4kh foreignObject[mask]{mask:none}.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .homeIcon-tEMBK1{width:10px;height:10px;background-size:100%;font-size:15px;line-height:20px}.bd-minimal .circleIconButton-jET_ig{height:20px;width:20px}.bd-minimal .circleIconButton-jET_ig svg{height:14px;width:14px}.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .friendsOnline-_wi_fM{margin-left:-15px;font-size:7px}.bd-minimal #bd-pub-li{height:16px}.bd-minimal #bd-pub-button{font-size:8px;line-height:16px;height:16px}.bd-minimal .wrapper-1Rf91z,.bd-minimal .wrapper-1Rf91z .scrollerWrap-1IAIlv,.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG{width:45px}.bd-minimal .wrapper-1Rf91z .guildSeparator-3s64Iy{margin-left:-15px}.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .listItem-2P_4kh .wrapper-sa6paO{height:20px;margin-top:0;margin-left:-12.5px}.bd-minimal .wrapper-1Rf91z .scroller-2FKFPG .iconBadge-2wi9r4{width:12px;height:12px;background-size:12px}.bd-minimal .container-2Thooq .avatarSmall-3ACRaI{width:15px;height:15px;background-size:15px 15px}.bd-minimal .container-2Thooq .avatarSmall-3ACRaI .status-oxiHuE{height:5px;width:5px}.bd-minimal .container-2Thooq .accountDetails-3k9g4n{transform:scale(.8)}.bd-minimal .container-2Thooq .button-2b6hmh{height:14px;width:14px;background-size:14px 14px;margin-left:3px}.bd-minimal .container-2Thooq .button-2b6hmh svg{height:14px;width:14px}.bda-dark .theme-dark .root-1gCeng,.bda-dark .theme-dark .theme-light .slide-2pHaq5{background:#36393f}.bda-dark .root-1gCeng .input-1mgnkM{color:#e3e5e8;border-bottom-color:#292b2f}.bda-dark .theme-dark .theme-dark .action-1lSjCi,.bda-dark .theme-dark .theme-light .action-1lSjCi{background:#2f3136}.bda-dark .theme-dark .theme-light .footer-3rDWdC{background:#2f3136;box-shadow:none}.bda-dark .theme-dark .theme-dark .or-3THJsp,.bda-dark .theme-dark .theme-light .or-3THJsp{background:#2f3136;order:2;height:56px;width:56px;top:103px;line-height:56px;left:calc(50% - 29px);border-radius:50%;border:2px solid #484b52}.bda-dark .theme-dark .create-3jownz{order:1}.bda-dark .theme-dark .join-33Tr-7{order:3}.bda-dark .theme-dark .theme-dark .actionIcon-2IISM_,.bda-dark .theme-dark .theme-light .actionIcon-2IISM_{filter:grayscale(100%) brightness(60%)}.bda-dark .theme-dark .theme-light .footer-2yfCgX{background:#2f3136}.bda-dark .theme-dark .regionSelectModal-12e-57{background:#36393f}.bda-dark .theme-dark .regionSelectModal-12e-57 .regionSelectModalOption-2DSIZ3{background:#2f3136;border:2px solid #484b52}.bd-switch{background-color:#72767d;border-radius:14px;width:42px;height:24px;opacity:1;overflow:hidden;user-select:none;position:relative;display:block;flex:0 0 auto;transition:background .15s ease-in-out,box-shadow .15s ease-in-out,border .15s ease-in-out,opacity .15s ease-in-out;margin-left:10px;box-shadow:inset 0 1px 1px rgba(0,0,0,.15)}.bd-switch::before{content:"";display:block;position:absolute;top:0;left:0;bottom:0;right:0;z-index:0;opacity:0;background-color:#000}.bd-switch::after{content:"";display:block;position:absolute;background-color:#fff;z-index:1;width:18px;margin:3px;border-radius:9px;height:18px;left:0;transition:transform .15s ease-in-out,width .1s ease-in-out,left .1s ease-in-out;box-shadow:0 2px 4px rgba(0,0,0,.3)}.bd-switch .bd-checkbox{position:absolute;width:100%;height:100%;opacity:0;padding:0;margin:0;z-index:2;cursor:pointer}.bd-switch-checked{background-color:var(--bd-blue)}.bd-switch-checked::after{transform:translate3d(18px,0,0)}.bd-switch-disabled{opacity:.3;cursor:not-allowed}.bd-addon-button{cursor:pointer}.bd-addon-button+.bd-addon-button{margin-left:5px}.bd-addon-controls{display:flex;align-items:center;justify-content:space-between}.bd-addon-controls .bd-search{font-size:13px;margin:0;width:200px}.bd-addon-dropdowns{display:flex}.bd-select-wrapper+.bd-select-wrapper{margin-left:10px}.bd-select-wrapper{color:#f6f6f7;font-size:13px;display:flex;align-items:center}.bd-select-wrapper label{opacity:.3;margin-right:5px}.bd-select{position:relative;cursor:pointer;color:#f6f6f7;font-size:13px;display:flex;align-items:center;justify-content:space-between;background-color:rgba(0,0,0,.1);border:1px solid rgba(0,0,0,.3);border-radius:3px;padding:5px 5px 5px 0}.bd-select.bd-select-transparent{background:0 0;border:0;padding:0}.bd-select-value{padding-left:12px}.bd-select-arrow{margin-left:10px}.bd-select .bd-select-options{position:absolute;background:#2f3136;border-radius:0 0 3px 3px;max-height:300px;min-width:calc(100% + 2px);overflow-y:auto;box-shadow:rgba(0,0,0,.3) 0 1px 5px 0;border:1px solid rgba(0,0,0,.3);border-top:0;margin-top:-1px;margin-left:-1px;z-index:3;top:100%}.bd-select-transparent .bd-select-options{border:1px solid rgba(0,0,0,.3);margin-top:3px;border-radius:3px}.bd-select .bd-select-option{padding:8px 12px;cursor:pointer;white-space:pre}.bd-select .bd-select-option:hover,.bd-select .bd-select-option.selected{background:#26272b}.bd-search-wrapper{padding:3px;border-radius:3px;outline:0;border:0;background-color:#202225;color:#fff;display:flex;align-items:center}.bd-search{padding:2px 3px;background:0 0;border:0;color:#fff;flex:1}.bd-search-wrapper>svg{margin-right:2px}.bd-chat-badge{vertical-align:bottom;line-height:1.375rem;display:inline-block;height:21px}.compact-T3H92H .bd-chat-badge{position:absolute;left:5px;top:4px;width:16px;display:inline-flex}.bd-member-badge{height:15px;margin-left:4px} \ No newline at end of file diff --git a/BetterDiscordApp/gulpfile.js b/BetterDiscordApp/gulpfile.js new file mode 100644 index 0000000..f04400f --- /dev/null +++ b/BetterDiscordApp/gulpfile.js @@ -0,0 +1,33 @@ +const gulp = require("gulp"); +const rename = require("gulp-rename"); +const minify = require("gulp-babel-minify"); +const csso = require("gulp-csso"); + +gulp.task("minify-js", minifyJS); +gulp.task("minify-css", minifyCSS); + +gulp.task("watch-js", function() { + return gulp.watch(["./js/main.js"], minifyJS); +}); + +gulp.task("watch-css", function() { + return gulp.watch(["./css/main.css"], minifyCSS); +}); + +gulp.task("watch", function() { + return gulp.watch(["./js/main.js", "./css/main.css"], gulp.series(minifyJS, minifyCSS)); +}); + +function minifyJS() { + return gulp.src("./js/main.js") + .pipe(minify({mangle: {keepClassName: true}})) + .pipe(rename("main.min.js")) + .pipe(gulp.dest("./js")); +} + +function minifyCSS() { + return gulp.src("./css/main.css") + .pipe(csso({restructure: false})) + .pipe(rename("main.min.css")) + .pipe(gulp.dest("./css")); +} \ No newline at end of file diff --git a/BetterDiscordApp/js/main.js b/BetterDiscordApp/js/main.js new file mode 100644 index 0000000..330d031 --- /dev/null +++ b/BetterDiscordApp/js/main.js @@ -0,0 +1,933 @@ +module.exports = +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = "./src/index.js"); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "./src/0globals.js": +/*!*************************!*\ + !*** ./src/0globals.js ***! + \*************************/ +/*! exports provided: minimumDiscordVersion, currentDiscordVersion, minSupportedVersion, bbdVersion, bbdChangelog, settings, defaultCookie, settingsCookie, bdpluginErrors, bdthemeErrors, bdConfig, bdthemes, bdplugins, pluginCookie, themeCookie */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"minimumDiscordVersion\", function() { return minimumDiscordVersion; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"currentDiscordVersion\", function() { return currentDiscordVersion; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"minSupportedVersion\", function() { return minSupportedVersion; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"bbdVersion\", function() { return bbdVersion; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"bbdChangelog\", function() { return bbdChangelog; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"settings\", function() { return settings; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"defaultCookie\", function() { return defaultCookie; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"settingsCookie\", function() { return settingsCookie; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"bdpluginErrors\", function() { return bdpluginErrors; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"bdthemeErrors\", function() { return bdthemeErrors; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"bdConfig\", function() { return bdConfig; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"bdthemes\", function() { return bdthemes; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"bdplugins\", function() { return bdplugins; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"pluginCookie\", function() { return pluginCookie; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"themeCookie\", function() { return themeCookie; });\n// var settingsPanel, voiceMode, pluginModule, themeModule, dMode, publicServersModule, mainCore, BDV2;\nconst minimumDiscordVersion = \"0.0.306\";\nconst currentDiscordVersion = window.DiscordNative && window.DiscordNative.remoteApp && window.DiscordNative.remoteApp.getVersion && window.DiscordNative.remoteApp.getVersion() || \"0.0.306\";\nconst minSupportedVersion = \"0.3.0\";\nconst bbdVersion = \"0.3.4\";\nconst bbdChangelog = {\n description: \"LightCord Edition.\",\n changes: [{\n title: \"What's New?\",\n items: [\"**LightCord** is now using BandagedBD. That means all plugins you were using can be used too !\", \"**Window Transparency** changes were made to more compatible with external window managers and addons like Glasscord.\", \"Initialization sequence has once again been changed slightly to hopefully improve loading times.\", \"We removed emotes. That's sad for people who were actually using it, but it was leading to problems like this https://github.com/rauenzi/BetterDiscordApp/issues/348.\"]\n }, {\n title: \"Bug Fixes\",\n type: \"fixed\",\n items: [\"Some fixes related to showing modals in the `BdApi`.\"]\n }]\n};\nconst settings = {\n \"Custom css live update\": {\n id: \"bda-css-0\",\n info: \"\",\n implemented: true,\n hidden: true,\n cat: \"core\"\n },\n \"Custom css auto udpate\": {\n id: \"bda-css-1\",\n info: \"\",\n implemented: true,\n hidden: true,\n cat: \"core\"\n },\n \"BetterDiscord Blue\": {\n id: \"bda-gs-b\",\n info: \"Replace Discord blue with BD Blue\",\n implemented: false,\n hidden: false,\n cat: \"core\"\n },\n\n /* Core */\n\n /* ====== */\n \"Public Servers\": {\n id: \"bda-gs-1\",\n info: \"Display public servers button\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"modules\"\n },\n \"Minimal Mode\": {\n id: \"bda-gs-2\",\n info: \"Hide elements and reduce the size of elements.\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"modules\"\n },\n \"Voice Mode\": {\n id: \"bda-gs-4\",\n info: \"Only show voice chat\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"modules\"\n },\n \"Hide Channels\": {\n id: \"bda-gs-3\",\n info: \"Hide channels in minimal mode\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"modules\"\n },\n \"Dark Mode\": {\n id: \"bda-gs-5\",\n info: \"Make certain elements dark by default(wip)\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"modules\"\n },\n \"Voice Disconnect\": {\n id: \"bda-dc-0\",\n info: \"Disconnect from voice server when closing Discord\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"modules\"\n },\n \"24 Hour Timestamps\": {\n id: \"bda-gs-6\",\n info: \"Replace 12hr timestamps with proper ones\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"modules\"\n },\n \"Colored Text\": {\n id: \"bda-gs-7\",\n info: \"Make text color the same as role color\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"modules\"\n },\n \"Normalize Classes\": {\n id: \"fork-ps-4\",\n info: \"Adds stable classes to elements to help themes. (e.g. adds .da-channels to .channels-Ie2l6A)\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"modules\"\n },\n\n /* Content */\n \"Content Error Modal\": {\n id: \"fork-ps-1\",\n info: \"Shows a modal with plugin/theme errors\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"content manager\"\n },\n \"Show Toasts\": {\n id: \"fork-ps-2\",\n info: \"Shows a small notification for important information\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"content manager\"\n },\n \"Scroll To Settings\": {\n id: \"fork-ps-3\",\n info: \"Auto-scrolls to a plugin's settings when the button is clicked (only if out of view)\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"content manager\"\n },\n \"Automatic Loading\": {\n id: \"fork-ps-5\",\n info: \"Automatically loads, reloads, and unloads plugins and themes\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"content manager\"\n },\n\n /* Developer */\n \"Developer Mode\": {\n id: \"bda-gs-8\",\n info: \"Developer Mode\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"developer settings\"\n },\n \"Copy Selector\": {\n id: \"fork-dm-1\",\n info: \"Adds a \\\"Copy Selector\\\" option to context menus when developer mode is active\",\n implemented: true,\n hidden: false,\n cat: \"core\",\n category: \"developer settings\"\n },\n \"React DevTools\": {\n id: \"reactDevTools\",\n info: \"Adds react developer tools to the devtools. Must be installed in Google Chrome on your pc.\",\n implemented: true,\n hidden: true,\n cat: \"core\",\n category: \"developer settings\"\n },\n\n /** LightCord */\n \"Disable BetterDiscord\": {\n id: \"bd-disable\",\n info: \"Disable Betterdiscord (plugins, themes, etc).\",\n implemented: true,\n hidden: false,\n cat: \"lightcord\",\n category: \"Lightcord\"\n },\n \"Calling Ring Beat\": {\n id: \"lightcord-2\",\n info: \"Enable Discord's special calling beat.\",\n implemented: true,\n hidden: false,\n cat: \"lightcord\",\n category: \"Lightcord\"\n },\n \"Developer Mode\": {\n id: \"lightcord-1\",\n info: \"Enable Discord's Internal Developer Options. This allow the \\\"Experiments\\\" tab and the \\\"Developer Options\\\" tab. (must close and reopen settings)\",\n implemented: true,\n hidden: false,\n cat: \"lightcord\",\n category: \"Lightcord\"\n },\n\n /** RichPresence */\n \"Enable\": {\n id: \"lightcord-presence-1\",\n info: \"Enable RichPresence below.\",\n implemented: true,\n hidden: false,\n cat: \"status\"\n }\n};\nconst defaultCookie = {\n \"bda-gs-1\": true,\n \"bda-gs-2\": false,\n \"bda-gs-3\": false,\n \"bda-gs-4\": false,\n \"bda-gs-5\": true,\n \"bda-gs-6\": false,\n \"bda-gs-7\": false,\n \"bda-gs-8\": false,\n \"bda-es-0\": true,\n \"bda-es-1\": true,\n \"bda-es-2\": true,\n \"bda-es-4\": false,\n \"bda-es-6\": true,\n \"bda-es-7\": true,\n \"bda-gs-b\": false,\n \"bda-es-8\": true,\n \"bda-dc-0\": false,\n \"bda-css-0\": false,\n \"bda-css-1\": false,\n \"bda-es-9\": true,\n \"fork-dm-1\": false,\n \"fork-ps-1\": true,\n \"fork-ps-2\": true,\n \"fork-ps-3\": true,\n \"fork-ps-4\": true,\n \"fork-ps-5\": true,\n \"fork-es-2\": false,\n \"fork-es-3\": true,\n \"fork-wp-1\": false,\n \"fork-wp-2\": false,\n \"fork-beta\": true,\n \"reactDevTools\": false,\n \"lightcord-1\": false,\n \"lightcord-2\": true,\n \"lightcord-presence-1\": false\n};\nconst settingsCookie = {};\nconst bdpluginErrors = [];\nconst bdthemeErrors = []; // define for backwards compatibility\n\nconst bdConfig = Object.create(BetterDiscordConfig);\nconst bdthemes = {};\nconst bdplugins = {};\nconst pluginCookie = {};\nconst themeCookie = {};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/0globals.js.js","sources":["webpack://BetterDiscord/./src/0globals.js?00d2"],"sourcesContent":["// var settingsPanel, voiceMode, pluginModule, themeModule, dMode, publicServersModule, mainCore, BDV2;\nexport const minimumDiscordVersion = \"0.0.306\";\nexport const currentDiscordVersion = window.DiscordNative && window.DiscordNative.remoteApp && window.DiscordNative.remoteApp.getVersion && window.DiscordNative.remoteApp.getVersion() || \"0.0.306\";\nexport const minSupportedVersion = \"0.3.0\";\nexport const bbdVersion = \"0.3.4\";\nexport const bbdChangelog = {\n  description: \"LightCord Edition.\",\n  changes: [{\n    title: \"What's New?\",\n    items: [\"**LightCord** is now using BandagedBD. That means all plugins you were using can be used too !\", \"**Window Transparency** changes were made to more compatible with external window managers and addons like Glasscord.\", \"Initialization sequence has once again been changed slightly to hopefully improve loading times.\", \"We removed emotes. That's sad for people who were actually using it, but it was leading to problems like this https://github.com/rauenzi/BetterDiscordApp/issues/348.\"]\n  }, {\n    title: \"Bug Fixes\",\n    type: \"fixed\",\n    items: [\"Some fixes related to showing modals in the `BdApi`.\"]\n  }]\n};\nexport const settings = {\n  \"Custom css live update\": {\n    id: \"bda-css-0\",\n    info: \"\",\n    implemented: true,\n    hidden: true,\n    cat: \"core\"\n  },\n  \"Custom css auto udpate\": {\n    id: \"bda-css-1\",\n    info: \"\",\n    implemented: true,\n    hidden: true,\n    cat: \"core\"\n  },\n  \"BetterDiscord Blue\": {\n    id: \"bda-gs-b\",\n    info: \"Replace Discord blue with BD Blue\",\n    implemented: false,\n    hidden: false,\n    cat: \"core\"\n  },\n\n  /* Core */\n\n  /* ====== */\n  \"Public Servers\": {\n    id: \"bda-gs-1\",\n    info: \"Display public servers button\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"modules\"\n  },\n  \"Minimal Mode\": {\n    id: \"bda-gs-2\",\n    info: \"Hide elements and reduce the size of elements.\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"modules\"\n  },\n  \"Voice Mode\": {\n    id: \"bda-gs-4\",\n    info: \"Only show voice chat\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"modules\"\n  },\n  \"Hide Channels\": {\n    id: \"bda-gs-3\",\n    info: \"Hide channels in minimal mode\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"modules\"\n  },\n  \"Dark Mode\": {\n    id: \"bda-gs-5\",\n    info: \"Make certain elements dark by default(wip)\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"modules\"\n  },\n  \"Voice Disconnect\": {\n    id: \"bda-dc-0\",\n    info: \"Disconnect from voice server when closing Discord\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"modules\"\n  },\n  \"24 Hour Timestamps\": {\n    id: \"bda-gs-6\",\n    info: \"Replace 12hr timestamps with proper ones\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"modules\"\n  },\n  \"Colored Text\": {\n    id: \"bda-gs-7\",\n    info: \"Make text color the same as role color\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"modules\"\n  },\n  \"Normalize Classes\": {\n    id: \"fork-ps-4\",\n    info: \"Adds stable classes to elements to help themes. (e.g. adds .da-channels to .channels-Ie2l6A)\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"modules\"\n  },\n\n  /* Content */\n  \"Content Error Modal\": {\n    id: \"fork-ps-1\",\n    info: \"Shows a modal with plugin/theme errors\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"content manager\"\n  },\n  \"Show Toasts\": {\n    id: \"fork-ps-2\",\n    info: \"Shows a small notification for important information\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"content manager\"\n  },\n  \"Scroll To Settings\": {\n    id: \"fork-ps-3\",\n    info: \"Auto-scrolls to a plugin's settings when the button is clicked (only if out of view)\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"content manager\"\n  },\n  \"Automatic Loading\": {\n    id: \"fork-ps-5\",\n    info: \"Automatically loads, reloads, and unloads plugins and themes\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"content manager\"\n  },\n\n  /* Developer */\n  \"Developer Mode\": {\n    id: \"bda-gs-8\",\n    info: \"Developer Mode\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"developer settings\"\n  },\n  \"Copy Selector\": {\n    id: \"fork-dm-1\",\n    info: \"Adds a \\\"Copy Selector\\\" option to context menus when developer mode is active\",\n    implemented: true,\n    hidden: false,\n    cat: \"core\",\n    category: \"developer settings\"\n  },\n  \"React DevTools\": {\n    id: \"reactDevTools\",\n    info: \"Adds react developer tools to the devtools. Must be installed in Google Chrome on your pc.\",\n    implemented: true,\n    hidden: true,\n    cat: \"core\",\n    category: \"developer settings\"\n  },\n\n  /** LightCord */\n  \"Disable BetterDiscord\": {\n    id: \"bd-disable\",\n    info: \"Disable Betterdiscord (plugins, themes, etc).\",\n    implemented: true,\n    hidden: false,\n    cat: \"lightcord\",\n    category: \"Lightcord\"\n  },\n  \"Calling Ring Beat\": {\n    id: \"lightcord-2\",\n    info: \"Enable Discord's special calling beat.\",\n    implemented: true,\n    hidden: false,\n    cat: \"lightcord\",\n    category: \"Lightcord\"\n  },\n  \"Developer Mode\": {\n    id: \"lightcord-1\",\n    info: \"Enable Discord's Internal Developer Options. This allow the \\\"Experiments\\\" tab and the \\\"Developer Options\\\" tab. (must close and reopen settings)\",\n    implemented: true,\n    hidden: false,\n    cat: \"lightcord\",\n    category: \"Lightcord\"\n  },\n\n  /** RichPresence */\n  \"Enable\": {\n    id: \"lightcord-presence-1\",\n    info: \"Enable RichPresence below.\",\n    implemented: true,\n    hidden: false,\n    cat: \"status\"\n  }\n};\nexport const defaultCookie = {\n  \"bda-gs-1\": true,\n  \"bda-gs-2\": false,\n  \"bda-gs-3\": false,\n  \"bda-gs-4\": false,\n  \"bda-gs-5\": true,\n  \"bda-gs-6\": false,\n  \"bda-gs-7\": false,\n  \"bda-gs-8\": false,\n  \"bda-es-0\": true,\n  \"bda-es-1\": true,\n  \"bda-es-2\": true,\n  \"bda-es-4\": false,\n  \"bda-es-6\": true,\n  \"bda-es-7\": true,\n  \"bda-gs-b\": false,\n  \"bda-es-8\": true,\n  \"bda-dc-0\": false,\n  \"bda-css-0\": false,\n  \"bda-css-1\": false,\n  \"bda-es-9\": true,\n  \"fork-dm-1\": false,\n  \"fork-ps-1\": true,\n  \"fork-ps-2\": true,\n  \"fork-ps-3\": true,\n  \"fork-ps-4\": true,\n  \"fork-ps-5\": true,\n  \"fork-es-2\": false,\n  \"fork-es-3\": true,\n  \"fork-wp-1\": false,\n  \"fork-wp-2\": false,\n  \"fork-beta\": true,\n  \"reactDevTools\": false,\n  \"lightcord-1\": false,\n  \"lightcord-2\": true,\n  \"lightcord-presence-1\": false\n};\nexport const settingsCookie = {};\nexport const bdpluginErrors = [];\nexport const bdthemeErrors = []; // define for backwards compatibility\n\nexport const bdConfig = Object.create(BetterDiscordConfig);\nexport const bdthemes = {};\nexport const bdplugins = {};\nexport const pluginCookie = {};\nexport const themeCookie = {};"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/0globals.js\n"); + +/***/ }), + +/***/ "./src/index.js": +/*!**********************!*\ + !*** ./src/index.js ***! + \**********************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return CoreWrapper; });\n/* harmony import */ var _localStorageFix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./localStorageFix */ \"./src/localStorageFix.js\");\n/* harmony import */ var _loadingIcon__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./loadingIcon */ \"./src/loadingIcon.js\");\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./0globals */ \"./src/0globals.js\");\n/* harmony import */ var _modules_bdApi__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./modules/bdApi */ \"./src/modules/bdApi.js\");\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _modules_pluginModule__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./modules/pluginModule */ \"./src/modules/pluginModule.js\");\n/* harmony import */ var _modules_themeModule__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./modules/themeModule */ \"./src/modules/themeModule.js\");\n/* harmony import */ var _modules_utils__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./modules/utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _modules_bdEvents__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./modules/bdEvents */ \"./src/modules/bdEvents.js\");\n/* harmony import */ var _modules_settingsPanel__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./modules/settingsPanel */ \"./src/modules/settingsPanel.js\");\n/* harmony import */ var _modules_dataStore__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./modules/dataStore */ \"./src/modules/dataStore.js\");\n/* harmony import */ var _modules_contentManager__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./modules/contentManager */ \"./src/modules/contentManager.js\");\n/* harmony import */ var _modules_classNormalizer__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./modules/classNormalizer */ \"./src/modules/classNormalizer.js\");\n/* harmony import */ var _modules_core__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./modules/core */ \"./src/modules/core.js\");\n\n\nObject(_localStorageFix__WEBPACK_IMPORTED_MODULE_0__[\"default\"])();\nObject(_loadingIcon__WEBPACK_IMPORTED_MODULE_1__[\"default\"])();\n\nconst deprecateGlobal = (key, value) => {\n // value = typeof(value) !== \"object\" ? value : new Proxy(value, {\n // get: function(obj, mod) {\n // if (!obj.hasOwnProperty(mod)) return undefined;\n // return obj[mod];\n // },\n // set: function(obj, mod) {\n // if (obj.hasOwnProperty(mod)) return Utils.err(\"Deprecated Global\", \"Trying to overwrite deprecated BD globals\");\n // }\n // });\n Object.defineProperty(window, key, {\n get() {\n _modules_utils__WEBPACK_IMPORTED_MODULE_7__[\"default\"].warn(\"Deprecated Global\", `\"${key}\" will be removed in future versions. Please only use BdApi.`);\n return value;\n }\n\n });\n};\n\n\nconst globalKeys = Object.keys(_0globals__WEBPACK_IMPORTED_MODULE_2__);\n\nfor (const key of globalKeys) deprecateGlobal(key, _0globals__WEBPACK_IMPORTED_MODULE_2__[key]);\n\n\n\n\n\n\n\n\n\n\n\ndeprecateGlobal(\"BDV2\", _modules_v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"]);\ndeprecateGlobal(\"pluginModule\", _modules_pluginModule__WEBPACK_IMPORTED_MODULE_5__[\"default\"]);\ndeprecateGlobal(\"themeModule\", _modules_themeModule__WEBPACK_IMPORTED_MODULE_6__[\"default\"]);\ndeprecateGlobal(\"Utils\", _modules_utils__WEBPACK_IMPORTED_MODULE_7__[\"default\"]);\ndeprecateGlobal(\"BDEvents\", _modules_bdEvents__WEBPACK_IMPORTED_MODULE_8__[\"default\"]);\ndeprecateGlobal(\"settingsPanel\", _modules_settingsPanel__WEBPACK_IMPORTED_MODULE_9__[\"default\"]);\ndeprecateGlobal(\"DataStore\", _modules_dataStore__WEBPACK_IMPORTED_MODULE_10__[\"default\"]);\ndeprecateGlobal(\"ContentManager\", _modules_contentManager__WEBPACK_IMPORTED_MODULE_11__[\"default\"]);\ndeprecateGlobal(\"ClassNormalizer\", _modules_classNormalizer__WEBPACK_IMPORTED_MODULE_12__[\"default\"]);\nwindow.BdApi = _modules_bdApi__WEBPACK_IMPORTED_MODULE_3__[\"default\"];\n\ndeprecateGlobal(\"mainCore\", _modules_core__WEBPACK_IMPORTED_MODULE_13__[\"default\"]);\nclass CoreWrapper {\n constructor(bdConfig) {\n _modules_core__WEBPACK_IMPORTED_MODULE_13__[\"default\"].setConfig(bdConfig);\n }\n\n init() {\n // deprecateGlobal(\"mainCore\", this.mainCore);\n _modules_core__WEBPACK_IMPORTED_MODULE_13__[\"default\"].init();\n }\n\n} // function patchModuleLoad() {\n// const namespace = \"betterdiscord\";\n// const prefix = `${namespace}/`;\n// const Module = require(\"module\");\n// const load = Module._load;\n// // const resolveFilename = Module._resolveFilename;\n// Module._load = function(request) {\n// if (request === namespace || request.startsWith(prefix)) {\n// const requested = request.substr(prefix.length);\n// if (requested == \"api\") return BdApi;\n// }\n// return load.apply(this, arguments);\n// };\n// // Module._resolveFilename = function (request, parent, isMain) {\n// // if (request === \"betterdiscord\" || request.startsWith(\"betterdiscord/\")) {\n// // const contentPath = PluginManager.getPluginPathByModule(parent);\n// // if (contentPath) return request;\n// // }\n// // return resolveFilename.apply(this, arguments);\n// // };\n// return function() {\n// Module._load = load;\n// };\n// }\n// patchModuleLoad();\n// var settingsPanel, voiceMode,, dMode, publicServersModule;\n// var bdConfig = null;\n\n__webpack_require__(/*! request */ \"request\"); // just in cache so plugin can require it too//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvaW5kZXguanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL2luZGV4LmpzP2JmNDUiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGxvY2FsU3RvcmFnZUZpeCBmcm9tIFwiLi9sb2NhbFN0b3JhZ2VGaXhcIjtcbmltcG9ydCBsb2FkaW5nSWNvbiBmcm9tIFwiLi9sb2FkaW5nSWNvblwiO1xubG9jYWxTdG9yYWdlRml4KCk7XG5sb2FkaW5nSWNvbigpO1xuXG5jb25zdCBkZXByZWNhdGVHbG9iYWwgPSAoa2V5LCB2YWx1ZSkgPT4ge1xuICAvLyB2YWx1ZSA9IHR5cGVvZih2YWx1ZSkgIT09IFwib2JqZWN0XCIgPyB2YWx1ZSA6IG5ldyBQcm94eSh2YWx1ZSwge1xuICAvLyAgICAgZ2V0OiBmdW5jdGlvbihvYmosIG1vZCkge1xuICAvLyAgICAgICAgIGlmICghb2JqLmhhc093blByb3BlcnR5KG1vZCkpIHJldHVybiB1bmRlZmluZWQ7XG4gIC8vICAgICAgICAgcmV0dXJuIG9ialttb2RdO1xuICAvLyAgICAgfSxcbiAgLy8gICAgIHNldDogZnVuY3Rpb24ob2JqLCBtb2QpIHtcbiAgLy8gICAgICAgICBpZiAob2JqLmhhc093blByb3BlcnR5KG1vZCkpIHJldHVybiBVdGlscy5lcnIoXCJEZXByZWNhdGVkIEdsb2JhbFwiLCBcIlRyeWluZyB0byBvdmVyd3JpdGUgZGVwcmVjYXRlZCBCRCBnbG9iYWxzXCIpO1xuICAvLyAgICAgfVxuICAvLyB9KTtcbiAgT2JqZWN0LmRlZmluZVByb3BlcnR5KHdpbmRvdywga2V5LCB7XG4gICAgZ2V0KCkge1xuICAgICAgVXRpbHMud2FybihcIkRlcHJlY2F0ZWQgR2xvYmFsXCIsIGBcIiR7a2V5fVwiIHdpbGwgYmUgcmVtb3ZlZCBpbiBmdXR1cmUgdmVyc2lvbnMuIFBsZWFzZSBvbmx5IHVzZSBCZEFwaS5gKTtcbiAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9XG5cbiAgfSk7XG59O1xuXG5pbXBvcnQgKiBhcyBHbG9iYWxzIGZyb20gXCIuLzBnbG9iYWxzXCI7XG5jb25zdCBnbG9iYWxLZXlzID0gT2JqZWN0LmtleXMoR2xvYmFscyk7XG5cbmZvciAoY29uc3Qga2V5IG9mIGdsb2JhbEtleXMpIGRlcHJlY2F0ZUdsb2JhbChrZXksIEdsb2JhbHNba2V5XSk7XG5cbmltcG9ydCBCZEFwaSBmcm9tIFwiLi9tb2R1bGVzL2JkQXBpXCI7XG5pbXBvcnQgQkRWMiBmcm9tIFwiLi9tb2R1bGVzL3YyXCI7XG5pbXBvcnQgcGx1Z2luTW9kdWxlIGZyb20gXCIuL21vZHVsZXMvcGx1Z2luTW9kdWxlXCI7XG5pbXBvcnQgdGhlbWVNb2R1bGUgZnJvbSBcIi4vbW9kdWxlcy90aGVtZU1vZHVsZVwiO1xuaW1wb3J0IFV0aWxzIGZyb20gXCIuL21vZHVsZXMvdXRpbHNcIjtcbmltcG9ydCBCREV2ZW50cyBmcm9tIFwiLi9tb2R1bGVzL2JkRXZlbnRzXCI7XG5pbXBvcnQgc2V0dGluZ3NQYW5lbCBmcm9tIFwiLi9tb2R1bGVzL3NldHRpbmdzUGFuZWxcIjtcbmltcG9ydCBEYXRhU3RvcmUgZnJvbSBcIi4vbW9kdWxlcy9kYXRhU3RvcmVcIjtcbmltcG9ydCBDb250ZW50TWFuYWdlciBmcm9tIFwiLi9tb2R1bGVzL2NvbnRlbnRNYW5hZ2VyXCI7XG5pbXBvcnQgQ2xhc3NOb3JtYWxpemVyIGZyb20gXCIuL21vZHVsZXMvY2xhc3NOb3JtYWxpemVyXCI7XG5kZXByZWNhdGVHbG9iYWwoXCJCRFYyXCIsIEJEVjIpO1xuZGVwcmVjYXRlR2xvYmFsKFwicGx1Z2luTW9kdWxlXCIsIHBsdWdpbk1vZHVsZSk7XG5kZXByZWNhdGVHbG9iYWwoXCJ0aGVtZU1vZHVsZVwiLCB0aGVtZU1vZHVsZSk7XG5kZXByZWNhdGVHbG9iYWwoXCJVdGlsc1wiLCBVdGlscyk7XG5kZXByZWNhdGVHbG9iYWwoXCJCREV2ZW50c1wiLCBCREV2ZW50cyk7XG5kZXByZWNhdGVHbG9iYWwoXCJzZXR0aW5nc1BhbmVsXCIsIHNldHRpbmdzUGFuZWwpO1xuZGVwcmVjYXRlR2xvYmFsKFwiRGF0YVN0b3JlXCIsIERhdGFTdG9yZSk7XG5kZXByZWNhdGVHbG9iYWwoXCJDb250ZW50TWFuYWdlclwiLCBDb250ZW50TWFuYWdlcik7XG5kZXByZWNhdGVHbG9iYWwoXCJDbGFzc05vcm1hbGl6ZXJcIiwgQ2xhc3NOb3JtYWxpemVyKTtcbndpbmRvdy5CZEFwaSA9IEJkQXBpO1xuaW1wb3J0IENvcmUgZnJvbSBcIi4vbW9kdWxlcy9jb3JlXCI7XG5kZXByZWNhdGVHbG9iYWwoXCJtYWluQ29yZVwiLCBDb3JlKTtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvcmVXcmFwcGVyIHtcbiAgY29uc3RydWN0b3IoYmRDb25maWcpIHtcbiAgICBDb3JlLnNldENvbmZpZyhiZENvbmZpZyk7XG4gIH1cblxuICBpbml0KCkge1xuICAgIC8vIGRlcHJlY2F0ZUdsb2JhbChcIm1haW5Db3JlXCIsIHRoaXMubWFpbkNvcmUpO1xuICAgIENvcmUuaW5pdCgpO1xuICB9XG5cbn0gLy8gZnVuY3Rpb24gcGF0Y2hNb2R1bGVMb2FkKCkge1xuLy8gICAgIGNvbnN0IG5hbWVzcGFjZSA9IFwiYmV0dGVyZGlzY29yZFwiO1xuLy8gICAgIGNvbnN0IHByZWZpeCA9IGAke25hbWVzcGFjZX0vYDtcbi8vICAgICBjb25zdCBNb2R1bGUgPSByZXF1aXJlKFwibW9kdWxlXCIpO1xuLy8gICAgIGNvbnN0IGxvYWQgPSBNb2R1bGUuX2xvYWQ7XG4vLyAgICAgLy8gY29uc3QgcmVzb2x2ZUZpbGVuYW1lID0gTW9kdWxlLl9yZXNvbHZlRmlsZW5hbWU7XG4vLyAgICAgTW9kdWxlLl9sb2FkID0gZnVuY3Rpb24ocmVxdWVzdCkge1xuLy8gICAgICAgICBpZiAocmVxdWVzdCA9PT0gbmFtZXNwYWNlIHx8IHJlcXVlc3Quc3RhcnRzV2l0aChwcmVmaXgpKSB7XG4vLyAgICAgICAgICAgICBjb25zdCByZXF1ZXN0ZWQgPSByZXF1ZXN0LnN1YnN0cihwcmVmaXgubGVuZ3RoKTtcbi8vICAgICAgICAgICAgIGlmIChyZXF1ZXN0ZWQgPT0gXCJhcGlcIikgcmV0dXJuIEJkQXBpO1xuLy8gICAgICAgICB9XG4vLyAgICAgICAgIHJldHVybiBsb2FkLmFwcGx5KHRoaXMsIGFyZ3VtZW50cyk7XG4vLyAgICAgfTtcbi8vICAgICAvLyBNb2R1bGUuX3Jlc29sdmVGaWxlbmFtZSA9IGZ1bmN0aW9uIChyZXF1ZXN0LCBwYXJlbnQsIGlzTWFpbikge1xuLy8gICAgIC8vICAgICBpZiAocmVxdWVzdCA9PT0gXCJiZXR0ZXJkaXNjb3JkXCIgfHwgcmVxdWVzdC5zdGFydHNXaXRoKFwiYmV0dGVyZGlzY29yZC9cIikpIHtcbi8vICAgICAvLyAgICAgICAgIGNvbnN0IGNvbnRlbnRQYXRoID0gUGx1Z2luTWFuYWdlci5nZXRQbHVnaW5QYXRoQnlNb2R1bGUocGFyZW50KTtcbi8vICAgICAvLyAgICAgICAgIGlmIChjb250ZW50UGF0aCkgcmV0dXJuIHJlcXVlc3Q7XG4vLyAgICAgLy8gICAgIH1cbi8vICAgICAvLyAgICAgcmV0dXJuIHJlc29sdmVGaWxlbmFtZS5hcHBseSh0aGlzLCBhcmd1bWVudHMpO1xuLy8gICAgIC8vIH07XG4vLyAgICAgcmV0dXJuIGZ1bmN0aW9uKCkge1xuLy8gICAgICAgICBNb2R1bGUuX2xvYWQgPSBsb2FkO1xuLy8gICAgIH07XG4vLyB9XG4vLyBwYXRjaE1vZHVsZUxvYWQoKTtcbi8vIHZhciBzZXR0aW5nc1BhbmVsLCB2b2ljZU1vZGUsLCBkTW9kZSwgcHVibGljU2VydmVyc01vZHVsZTtcbi8vIHZhciBiZENvbmZpZyA9IG51bGw7XG5cbnJlcXVpcmUoXCJyZXF1ZXN0XCIpOyAvLyBqdXN0IGluIGNhY2hlIHNvIHBsdWdpbiBjYW4gcmVxdWlyZSBpdCB0b28iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/index.js\n"); + +/***/ }), + +/***/ "./src/loadingIcon.js": +/*!****************************!*\ + !*** ./src/loadingIcon.js ***! + \****************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__[\"default\"] = (() => {\n const v2Loader = document.createElement(\"div\");\n v2Loader.className = \"bd-loaderv2\";\n v2Loader.title = \"BandagedBD is loading...\";\n document.body.appendChild(v2Loader);\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbG9hZGluZ0ljb24uanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL2xvYWRpbmdJY29uLmpzP2NlZGIiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGRlZmF1bHQgKCgpID0+IHtcbiAgY29uc3QgdjJMb2FkZXIgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwiZGl2XCIpO1xuICB2MkxvYWRlci5jbGFzc05hbWUgPSBcImJkLWxvYWRlcnYyXCI7XG4gIHYyTG9hZGVyLnRpdGxlID0gXCJCYW5kYWdlZEJEIGlzIGxvYWRpbmcuLi5cIjtcbiAgZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZCh2MkxvYWRlcik7XG59KTsiXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/loadingIcon.js\n"); + +/***/ }), + +/***/ "./src/localStorageFix.js": +/*!********************************!*\ + !*** ./src/localStorageFix.js ***! + \********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__[\"default\"] = (function () {\n const contentWindowGetter = Object.getOwnPropertyDescriptor(HTMLIFrameElement.prototype, \"contentWindow\").get;\n Object.defineProperty(HTMLIFrameElement.prototype, \"contentWindow\", {\n get: function () {\n const contentWindow = Reflect.apply(contentWindowGetter, this, arguments);\n return new Proxy(contentWindow, {\n getOwnPropertyDescriptor: function (obj, prop) {\n if (prop === \"localStorage\") return undefined;\n return Object.getOwnPropertyDescriptor(obj, prop);\n },\n get: function (obj, prop) {\n if (prop === \"localStorage\") return null;\n const val = obj[prop];\n if (typeof val === \"function\") return val.bind(obj);\n return val;\n }\n });\n }\n }); // Prevent interception by patching Reflect.apply and Function.prototype.bind\n\n Object.defineProperty(Reflect, \"apply\", {\n value: Reflect.apply,\n writable: false,\n configurable: false\n });\n Object.defineProperty(Function.prototype, \"bind\", {\n value: Function.prototype.bind,\n writable: false,\n configurable: false\n });\n const oOpen = XMLHttpRequest.prototype.open;\n\n XMLHttpRequest.prototype.open = function () {\n const url = arguments[1];\n if (url.toLowerCase().includes(\"api/webhooks\")) return null;\n return Reflect.apply(oOpen, this, arguments);\n };\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbG9jYWxTdG9yYWdlRml4LmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQmV0dGVyRGlzY29yZC8uL3NyYy9sb2NhbFN0b3JhZ2VGaXguanM/MTUzMyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZGVmYXVsdCBmdW5jdGlvbiAoKSB7XG4gIGNvbnN0IGNvbnRlbnRXaW5kb3dHZXR0ZXIgPSBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yKEhUTUxJRnJhbWVFbGVtZW50LnByb3RvdHlwZSwgXCJjb250ZW50V2luZG93XCIpLmdldDtcbiAgT2JqZWN0LmRlZmluZVByb3BlcnR5KEhUTUxJRnJhbWVFbGVtZW50LnByb3RvdHlwZSwgXCJjb250ZW50V2luZG93XCIsIHtcbiAgICBnZXQ6IGZ1bmN0aW9uICgpIHtcbiAgICAgIGNvbnN0IGNvbnRlbnRXaW5kb3cgPSBSZWZsZWN0LmFwcGx5KGNvbnRlbnRXaW5kb3dHZXR0ZXIsIHRoaXMsIGFyZ3VtZW50cyk7XG4gICAgICByZXR1cm4gbmV3IFByb3h5KGNvbnRlbnRXaW5kb3csIHtcbiAgICAgICAgZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yOiBmdW5jdGlvbiAob2JqLCBwcm9wKSB7XG4gICAgICAgICAgaWYgKHByb3AgPT09IFwibG9jYWxTdG9yYWdlXCIpIHJldHVybiB1bmRlZmluZWQ7XG4gICAgICAgICAgcmV0dXJuIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Iob2JqLCBwcm9wKTtcbiAgICAgICAgfSxcbiAgICAgICAgZ2V0OiBmdW5jdGlvbiAob2JqLCBwcm9wKSB7XG4gICAgICAgICAgaWYgKHByb3AgPT09IFwibG9jYWxTdG9yYWdlXCIpIHJldHVybiBudWxsO1xuICAgICAgICAgIGNvbnN0IHZhbCA9IG9ialtwcm9wXTtcbiAgICAgICAgICBpZiAodHlwZW9mIHZhbCA9PT0gXCJmdW5jdGlvblwiKSByZXR1cm4gdmFsLmJpbmQob2JqKTtcbiAgICAgICAgICByZXR1cm4gdmFsO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH0pOyAvLyBQcmV2ZW50IGludGVyY2VwdGlvbiBieSBwYXRjaGluZyBSZWZsZWN0LmFwcGx5IGFuZCBGdW5jdGlvbi5wcm90b3R5cGUuYmluZFxuXG4gIE9iamVjdC5kZWZpbmVQcm9wZXJ0eShSZWZsZWN0LCBcImFwcGx5XCIsIHtcbiAgICB2YWx1ZTogUmVmbGVjdC5hcHBseSxcbiAgICB3cml0YWJsZTogZmFsc2UsXG4gICAgY29uZmlndXJhYmxlOiBmYWxzZVxuICB9KTtcbiAgT2JqZWN0LmRlZmluZVByb3BlcnR5KEZ1bmN0aW9uLnByb3RvdHlwZSwgXCJiaW5kXCIsIHtcbiAgICB2YWx1ZTogRnVuY3Rpb24ucHJvdG90eXBlLmJpbmQsXG4gICAgd3JpdGFibGU6IGZhbHNlLFxuICAgIGNvbmZpZ3VyYWJsZTogZmFsc2VcbiAgfSk7XG4gIGNvbnN0IG9PcGVuID0gWE1MSHR0cFJlcXVlc3QucHJvdG90eXBlLm9wZW47XG5cbiAgWE1MSHR0cFJlcXVlc3QucHJvdG90eXBlLm9wZW4gPSBmdW5jdGlvbiAoKSB7XG4gICAgY29uc3QgdXJsID0gYXJndW1lbnRzWzFdO1xuICAgIGlmICh1cmwudG9Mb3dlckNhc2UoKS5pbmNsdWRlcyhcImFwaS93ZWJob29rc1wiKSkgcmV0dXJuIG51bGw7XG4gICAgcmV0dXJuIFJlZmxlY3QuYXBwbHkob09wZW4sIHRoaXMsIGFyZ3VtZW50cyk7XG4gIH07XG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/localStorageFix.js\n"); + +/***/ }), + +/***/ "./src/modules/24hour.js": +/*!*******************************!*\ + !*** ./src/modules/24hour.js ***! + \*******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _v2__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class TFHour {\n inject24Hour() {\n if (this.cancel24Hour) return;\n const twelveHour = new RegExp(`([0-9]{1,2}):([0-9]{1,2})\\\\s(AM|PM)`);\n\n const convert = data => {\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-gs-6\"]) return;\n const matched = data.returnValue.match(twelveHour);\n if (!matched || matched.length !== 4) return;\n if (matched[3] === \"AM\") return data.returnValue = data.returnValue.replace(matched[0], `${matched[1] === \"12\" ? \"00\" : matched[1].padStart(2, \"0\")}:${matched[2]}`);\n return data.returnValue = data.returnValue.replace(matched[0], `${matched[1] === \"12\" ? \"12\" : parseInt(matched[1]) + 12}:${matched[2]}`);\n };\n\n const cancelCozy = _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].monkeyPatch(_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].TimeFormatter, \"calendarFormat\", {\n after: convert\n }); // Called in Cozy mode\n\n const cancelCompact = _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].monkeyPatch(_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].TimeFormatter, \"dateFormat\", {\n after: convert\n }); // Called in Compact mode\n\n this.cancel24Hour = () => {\n cancelCozy();\n cancelCompact();\n }; // Cancel both\n\n }\n\n remove24Hour() {\n if (this.cancel24Hour) this.cancel24Hour();\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbW9kdWxlcy8yNGhvdXIuanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL21vZHVsZXMvMjRob3VyLmpzPzc4OWYiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc2V0dGluZ3NDb29raWUgfSBmcm9tIFwiLi4vMGdsb2JhbHNcIjtcbmltcG9ydCBCRFYyIGZyb20gXCIuL3YyXCI7XG5pbXBvcnQgVXRpbHMgZnJvbSBcIi4vdXRpbHNcIjtcbmV4cG9ydCBkZWZhdWx0IG5ldyBjbGFzcyBURkhvdXIge1xuICBpbmplY3QyNEhvdXIoKSB7XG4gICAgaWYgKHRoaXMuY2FuY2VsMjRIb3VyKSByZXR1cm47XG4gICAgY29uc3QgdHdlbHZlSG91ciA9IG5ldyBSZWdFeHAoYChbMC05XXsxLDJ9KTooWzAtOV17MSwyfSlcXFxccyhBTXxQTSlgKTtcblxuICAgIGNvbnN0IGNvbnZlcnQgPSBkYXRhID0+IHtcbiAgICAgIGlmICghc2V0dGluZ3NDb29raWVbXCJiZGEtZ3MtNlwiXSkgcmV0dXJuO1xuICAgICAgY29uc3QgbWF0Y2hlZCA9IGRhdGEucmV0dXJuVmFsdWUubWF0Y2godHdlbHZlSG91cik7XG4gICAgICBpZiAoIW1hdGNoZWQgfHwgbWF0Y2hlZC5sZW5ndGggIT09IDQpIHJldHVybjtcbiAgICAgIGlmIChtYXRjaGVkWzNdID09PSBcIkFNXCIpIHJldHVybiBkYXRhLnJldHVyblZhbHVlID0gZGF0YS5yZXR1cm5WYWx1ZS5yZXBsYWNlKG1hdGNoZWRbMF0sIGAke21hdGNoZWRbMV0gPT09IFwiMTJcIiA/IFwiMDBcIiA6IG1hdGNoZWRbMV0ucGFkU3RhcnQoMiwgXCIwXCIpfToke21hdGNoZWRbMl19YCk7XG4gICAgICByZXR1cm4gZGF0YS5yZXR1cm5WYWx1ZSA9IGRhdGEucmV0dXJuVmFsdWUucmVwbGFjZShtYXRjaGVkWzBdLCBgJHttYXRjaGVkWzFdID09PSBcIjEyXCIgPyBcIjEyXCIgOiBwYXJzZUludChtYXRjaGVkWzFdKSArIDEyfToke21hdGNoZWRbMl19YCk7XG4gICAgfTtcblxuICAgIGNvbnN0IGNhbmNlbENvenkgPSBVdGlscy5tb25rZXlQYXRjaChCRFYyLlRpbWVGb3JtYXR0ZXIsIFwiY2FsZW5kYXJGb3JtYXRcIiwge1xuICAgICAgYWZ0ZXI6IGNvbnZlcnRcbiAgICB9KTsgLy8gQ2FsbGVkIGluIENvenkgbW9kZVxuXG4gICAgY29uc3QgY2FuY2VsQ29tcGFjdCA9IFV0aWxzLm1vbmtleVBhdGNoKEJEVjIuVGltZUZvcm1hdHRlciwgXCJkYXRlRm9ybWF0XCIsIHtcbiAgICAgIGFmdGVyOiBjb252ZXJ0XG4gICAgfSk7IC8vIENhbGxlZCBpbiBDb21wYWN0IG1vZGVcblxuICAgIHRoaXMuY2FuY2VsMjRIb3VyID0gKCkgPT4ge1xuICAgICAgY2FuY2VsQ296eSgpO1xuICAgICAgY2FuY2VsQ29tcGFjdCgpO1xuICAgIH07IC8vIENhbmNlbCBib3RoXG5cbiAgfVxuXG4gIHJlbW92ZTI0SG91cigpIHtcbiAgICBpZiAodGhpcy5jYW5jZWwyNEhvdXIpIHRoaXMuY2FuY2VsMjRIb3VyKCk7XG4gIH1cblxufSgpOyJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/modules/24hour.js\n"); + +/***/ }), + +/***/ "./src/modules/CustomRichPresence.js": +/*!*******************************************!*\ + !*** ./src/modules/CustomRichPresence.js ***! + \*******************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _v2__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class CustomRichPresence {\n constructor() {\n this.enabled = false;\n }\n\n enable() {\n if (this.enabled) return;\n this.enabled = true;\n console.log(\"Enabling custom RichPresence\");\n }\n\n disable() {\n if (!this.enabled) return;\n this.enabled = false;\n console.log(\"Disabling custom RichPresence\");\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbW9kdWxlcy9DdXN0b21SaWNoUHJlc2VuY2UuanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL21vZHVsZXMvQ3VzdG9tUmljaFByZXNlbmNlLmpzPzE4MzUiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc2V0dGluZ3NDb29raWUgfSBmcm9tIFwiLi4vMGdsb2JhbHNcIjtcbmltcG9ydCBCRFYyIGZyb20gXCIuL3YyXCI7XG5pbXBvcnQgVXRpbHMgZnJvbSBcIi4vdXRpbHNcIjtcbmV4cG9ydCBkZWZhdWx0IG5ldyBjbGFzcyBDdXN0b21SaWNoUHJlc2VuY2Uge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLmVuYWJsZWQgPSBmYWxzZTtcbiAgfVxuXG4gIGVuYWJsZSgpIHtcbiAgICBpZiAodGhpcy5lbmFibGVkKSByZXR1cm47XG4gICAgdGhpcy5lbmFibGVkID0gdHJ1ZTtcbiAgICBjb25zb2xlLmxvZyhcIkVuYWJsaW5nIGN1c3RvbSBSaWNoUHJlc2VuY2VcIik7XG4gIH1cblxuICBkaXNhYmxlKCkge1xuICAgIGlmICghdGhpcy5lbmFibGVkKSByZXR1cm47XG4gICAgdGhpcy5lbmFibGVkID0gZmFsc2U7XG4gICAgY29uc29sZS5sb2coXCJEaXNhYmxpbmcgY3VzdG9tIFJpY2hQcmVzZW5jZVwiKTtcbiAgfVxuXG59KCk7Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/modules/CustomRichPresence.js\n"); + +/***/ }), + +/***/ "./src/modules/bdApi.js": +/*!******************************!*\ + !*** ./src/modules/bdApi.js ***! + \******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _core__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./core */ \"./src/modules/core.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _v2__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _dataStore__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./dataStore */ \"./src/modules/dataStore.js\");\n/* harmony import */ var _pluginModule__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./pluginModule */ \"./src/modules/pluginModule.js\");\n/* harmony import */ var _themeModule__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./themeModule */ \"./src/modules/themeModule.js\");\n/* harmony import */ var _settingsPanel__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./settingsPanel */ \"./src/modules/settingsPanel.js\");\n/* harmony import */ var _domtools__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./domtools */ \"./src/modules/domtools.js\");\n\n\n\n\n\n\n\n\n\nconst BdApi = {\n get React() {\n return _v2__WEBPACK_IMPORTED_MODULE_3__[\"default\"].React;\n },\n\n get ReactDOM() {\n return _v2__WEBPACK_IMPORTED_MODULE_3__[\"default\"].ReactDom;\n },\n\n get ReactComponent() {\n return _v2__WEBPACK_IMPORTED_MODULE_3__[\"default\"].ReactComponent;\n },\n\n get WindowConfigFile() {\n return _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].WindowConfigFile;\n },\n\n get settings() {\n return _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settings\"];\n },\n\n get emotes() {\n return {};\n },\n\n // deprecated, deleted all emotes from betterdiscord.\n get screenWidth() {\n return Math.max(document.documentElement.clientWidth, window.innerWidth || 0);\n },\n\n get screenHeight() {\n return Math.max(document.documentElement.clientHeight, window.innerHeight || 0);\n }\n\n};\n\nBdApi.getAllWindowPreferences = function () {\n return _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].getAllWindowPreferences();\n};\n\nBdApi.getWindowPreference = function (key) {\n return _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].getWindowPreference(key);\n};\n\nBdApi.setWindowPreference = function (key, value) {\n return _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].setWindowPreference(key, value);\n}; //Inject CSS to document head\n//id = id of element\n//css = custom css\n\n\nBdApi.injectCSS = function (id, css) {\n _domtools__WEBPACK_IMPORTED_MODULE_8__[\"default\"].addStyle(_domtools__WEBPACK_IMPORTED_MODULE_8__[\"default\"].escapeID(id), css);\n}; //Clear css/remove any element\n//id = id of element\n\n\nBdApi.clearCSS = function (id) {\n _domtools__WEBPACK_IMPORTED_MODULE_8__[\"default\"].removeStyle(_domtools__WEBPACK_IMPORTED_MODULE_8__[\"default\"].escapeID(id));\n}; //Inject CSS to document head\n//id = id of element\n//css = custom css\n\n\nBdApi.linkJS = function (id, url) {\n _domtools__WEBPACK_IMPORTED_MODULE_8__[\"default\"].addScript(_domtools__WEBPACK_IMPORTED_MODULE_8__[\"default\"].escapeID(id), url);\n}; //Clear css/remove any element\n//id = id of element\n\n\nBdApi.unlinkJS = function (id) {\n _domtools__WEBPACK_IMPORTED_MODULE_8__[\"default\"].removeScript(_domtools__WEBPACK_IMPORTED_MODULE_8__[\"default\"].escapeID(id));\n}; //Get another plugin\n//name = name of plugin\n\n\nBdApi.getPlugin = function (name) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"].hasOwnProperty(name)) {\n return _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][name].plugin;\n }\n\n return null;\n}; //Get BetterDiscord Core\n\n\nBdApi.getCore = function () {\n _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].warn(\"Deprecation Notice\", `BdApi.getCore() will be removed in future versions.`);\n return _core__WEBPACK_IMPORTED_MODULE_1__[\"default\"];\n};\n/**\r\n * Shows a generic but very customizable modal.\r\n * @param {string} title - title of the modal\r\n * @param {string} content - a string of text to display in the modal\r\n */\n\n\nBdApi.alert = function (title, content) {\n return _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].showConfirmationModal(title, content, {\n cancelText: null\n });\n};\n/**\r\n * Shows a generic but very customizable confirmation modal with optional confirm and cancel callbacks.\r\n * @param {string} title - title of the modal\r\n * @param {(string|ReactElement|Array)} children - a single or mixed array of react elements and strings. Every string is wrapped in Discord's `Markdown` component so strings will show and render properly.\r\n * @param {object} [options] - options to modify the modal\r\n * @param {boolean} [options.danger=false] - whether the main button should be red or not\r\n * @param {string} [options.confirmText=Okay] - text for the confirmation/submit button\r\n * @param {string} [options.cancelText=Cancel] - text for the cancel button\r\n * @param {callable} [options.onConfirm=NOOP] - callback to occur when clicking the submit button\r\n * @param {callable} [options.onCancel=NOOP] - callback to occur when clicking the cancel button\r\n * @param {string} [options.key] - key used to identify the modal. If not provided, one is generated and returned\r\n * @returns {string} - the key used for this modal\r\n */\n\n\nBdApi.showConfirmationModal = function (title, content, options = {}) {\n return _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].showConfirmationModal(title, content, options);\n}; //Show toast alert\n\n\nBdApi.showToast = function (content, options = {}) {\n _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].showToast(content, options);\n}; // Finds module\n\n\nBdApi.findModule = function (filter) {\n return _v2__WEBPACK_IMPORTED_MODULE_3__[\"default\"].WebpackModules.find(filter);\n}; // Finds module\n\n\nBdApi.findAllModules = function (filter) {\n return _v2__WEBPACK_IMPORTED_MODULE_3__[\"default\"].WebpackModules.findAll(filter);\n}; // Finds module\n\n\nBdApi.findModuleByProps = function (...props) {\n return _v2__WEBPACK_IMPORTED_MODULE_3__[\"default\"].WebpackModules.findByUniqueProperties(props);\n};\n\nBdApi.findModuleByPrototypes = function (...protos) {\n return _v2__WEBPACK_IMPORTED_MODULE_3__[\"default\"].WebpackModules.findByPrototypes(protos);\n};\n\nBdApi.findModuleByDisplayName = function (name) {\n return _v2__WEBPACK_IMPORTED_MODULE_3__[\"default\"].WebpackModules.findByDisplayName(name);\n}; // Gets react instance\n\n\nBdApi.getInternalInstance = function (node) {\n if (!(node instanceof window.jQuery) && !(node instanceof Element)) return undefined;\n if (node instanceof jQuery) node = node[0];\n return _v2__WEBPACK_IMPORTED_MODULE_3__[\"default\"].getInternalInstance(node);\n}; // Gets data\n\n\nBdApi.loadData = function (pluginName, key) {\n return _dataStore__WEBPACK_IMPORTED_MODULE_4__[\"default\"].getPluginData(pluginName, key);\n};\n\nBdApi.getData = BdApi.loadData; // Sets data\n\nBdApi.saveData = function (pluginName, key, data) {\n return _dataStore__WEBPACK_IMPORTED_MODULE_4__[\"default\"].setPluginData(pluginName, key, data);\n};\n\nBdApi.setData = BdApi.saveData; // Deletes data\n\nBdApi.deleteData = function (pluginName, key) {\n return _dataStore__WEBPACK_IMPORTED_MODULE_4__[\"default\"].deletePluginData(pluginName, key);\n}; // Patches other functions\n\n\nBdApi.monkeyPatch = function (what, methodName, options) {\n return _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].monkeyPatch(what, methodName, options);\n}; // Event when element is removed\n\n\nBdApi.onRemoved = function (node, callback) {\n return _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].onRemoved(node, callback);\n}; // Wraps function in try..catch\n\n\nBdApi.suppressErrors = function (method, message) {\n return _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].suppressErrors(method, message);\n}; // Tests for valid JSON\n\n\nBdApi.testJSON = function (data) {\n return _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].testJSON(data);\n};\n\nBdApi.isPluginEnabled = function (name) {\n return !!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][name];\n};\n\nBdApi.isThemeEnabled = function (name) {\n return !!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"][name];\n};\n\nBdApi.isSettingEnabled = function (id) {\n return !!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][id];\n};\n\nBdApi.enableSetting = function (id) {\n return _settingsPanel__WEBPACK_IMPORTED_MODULE_7__[\"default\"].onChange(id, true);\n};\n\nBdApi.disableSetting = function (id) {\n return _settingsPanel__WEBPACK_IMPORTED_MODULE_7__[\"default\"].onChange(id, false);\n};\n\nBdApi.toggleSetting = function (id) {\n return _settingsPanel__WEBPACK_IMPORTED_MODULE_7__[\"default\"].onChange(id, !_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][id]);\n}; // Gets data\n\n\nBdApi.getBDData = function (key) {\n return _dataStore__WEBPACK_IMPORTED_MODULE_4__[\"default\"].getBDData(key);\n}; // Sets data\n\n\nBdApi.setBDData = function (key, data) {\n return _dataStore__WEBPACK_IMPORTED_MODULE_4__[\"default\"].setBDData(key, data);\n};\n\nconst makeAddonAPI = (cookie, list, manager) => new class AddonAPI {\n get folder() {\n return manager.folder;\n }\n\n isEnabled(name) {\n return !!cookie[name];\n }\n\n enable(name) {\n return manager.enable(name);\n }\n\n disable(name) {\n return manager.disable(name);\n }\n\n toggle(name) {\n if (cookie[name]) this.disable(name);else this.enable(name);\n }\n\n reload(name) {\n return manager.reload(name);\n }\n\n get(name) {\n if (list.hasOwnProperty(name)) {\n if (list[name].plugin) return list[name].plugin;\n return list[name];\n }\n\n return null;\n }\n\n getAll() {\n return Object.keys(list).map(k => this.get(k)).filter(a => a);\n }\n\n}();\n\nBdApi.Plugins = makeAddonAPI(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"], _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"], _pluginModule__WEBPACK_IMPORTED_MODULE_5__[\"default\"]);\nBdApi.Themes = makeAddonAPI(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"], _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"], _themeModule__WEBPACK_IMPORTED_MODULE_6__[\"default\"]);\n/* harmony default export */ __webpack_exports__[\"default\"] = (BdApi);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/modules/bdApi.js.js","sources":["webpack://BetterDiscord/./src/modules/bdApi.js?a9a3"],"sourcesContent":["import { pluginCookie, themeCookie, bdplugins, bdthemes, settingsCookie, settings } from \"../0globals\";\nimport mainCore from \"./core\";\nimport Utils from \"./utils\";\nimport BDV2 from \"./v2\";\nimport DataStore from \"./dataStore\";\nimport pluginModule from \"./pluginModule\";\nimport themeModule from \"./themeModule\";\nimport settingsPanel from \"./settingsPanel\";\nimport DOM from \"./domtools\";\nconst BdApi = {\n  get React() {\n    return BDV2.React;\n  },\n\n  get ReactDOM() {\n    return BDV2.ReactDom;\n  },\n\n  get ReactComponent() {\n    return BDV2.ReactComponent;\n  },\n\n  get WindowConfigFile() {\n    return Utils.WindowConfigFile;\n  },\n\n  get settings() {\n    return settings;\n  },\n\n  get emotes() {\n    return {};\n  },\n\n  // deprecated, deleted all emotes from betterdiscord.\n  get screenWidth() {\n    return Math.max(document.documentElement.clientWidth, window.innerWidth || 0);\n  },\n\n  get screenHeight() {\n    return Math.max(document.documentElement.clientHeight, window.innerHeight || 0);\n  }\n\n};\n\nBdApi.getAllWindowPreferences = function () {\n  return Utils.getAllWindowPreferences();\n};\n\nBdApi.getWindowPreference = function (key) {\n  return Utils.getWindowPreference(key);\n};\n\nBdApi.setWindowPreference = function (key, value) {\n  return Utils.setWindowPreference(key, value);\n}; //Inject CSS to document head\n//id = id of element\n//css = custom css\n\n\nBdApi.injectCSS = function (id, css) {\n  DOM.addStyle(DOM.escapeID(id), css);\n}; //Clear css/remove any element\n//id = id of element\n\n\nBdApi.clearCSS = function (id) {\n  DOM.removeStyle(DOM.escapeID(id));\n}; //Inject CSS to document head\n//id = id of element\n//css = custom css\n\n\nBdApi.linkJS = function (id, url) {\n  DOM.addScript(DOM.escapeID(id), url);\n}; //Clear css/remove any element\n//id = id of element\n\n\nBdApi.unlinkJS = function (id) {\n  DOM.removeScript(DOM.escapeID(id));\n}; //Get another plugin\n//name = name of plugin\n\n\nBdApi.getPlugin = function (name) {\n  if (bdplugins.hasOwnProperty(name)) {\n    return bdplugins[name].plugin;\n  }\n\n  return null;\n}; //Get BetterDiscord Core\n\n\nBdApi.getCore = function () {\n  Utils.warn(\"Deprecation Notice\", `BdApi.getCore() will be removed in future versions.`);\n  return mainCore;\n};\n/**\r\n * Shows a generic but very customizable modal.\r\n * @param {string} title - title of the modal\r\n * @param {string} content - a string of text to display in the modal\r\n */\n\n\nBdApi.alert = function (title, content) {\n  return Utils.showConfirmationModal(title, content, {\n    cancelText: null\n  });\n};\n/**\r\n * Shows a generic but very customizable confirmation modal with optional confirm and cancel callbacks.\r\n * @param {string} title - title of the modal\r\n * @param {(string|ReactElement|Array<string|ReactElement>)} children - a single or mixed array of react elements and strings. Every string is wrapped in Discord's `Markdown` component so strings will show and render properly.\r\n * @param {object} [options] - options to modify the modal\r\n * @param {boolean} [options.danger=false] - whether the main button should be red or not\r\n * @param {string} [options.confirmText=Okay] - text for the confirmation/submit button\r\n * @param {string} [options.cancelText=Cancel] - text for the cancel button\r\n * @param {callable} [options.onConfirm=NOOP] - callback to occur when clicking the submit button\r\n * @param {callable} [options.onCancel=NOOP] - callback to occur when clicking the cancel button\r\n * @param {string} [options.key] - key used to identify the modal. If not provided, one is generated and returned\r\n * @returns {string} - the key used for this modal\r\n */\n\n\nBdApi.showConfirmationModal = function (title, content, options = {}) {\n  return Utils.showConfirmationModal(title, content, options);\n}; //Show toast alert\n\n\nBdApi.showToast = function (content, options = {}) {\n  Utils.showToast(content, options);\n}; // Finds module\n\n\nBdApi.findModule = function (filter) {\n  return BDV2.WebpackModules.find(filter);\n}; // Finds module\n\n\nBdApi.findAllModules = function (filter) {\n  return BDV2.WebpackModules.findAll(filter);\n}; // Finds module\n\n\nBdApi.findModuleByProps = function (...props) {\n  return BDV2.WebpackModules.findByUniqueProperties(props);\n};\n\nBdApi.findModuleByPrototypes = function (...protos) {\n  return BDV2.WebpackModules.findByPrototypes(protos);\n};\n\nBdApi.findModuleByDisplayName = function (name) {\n  return BDV2.WebpackModules.findByDisplayName(name);\n}; // Gets react instance\n\n\nBdApi.getInternalInstance = function (node) {\n  if (!(node instanceof window.jQuery) && !(node instanceof Element)) return undefined;\n  if (node instanceof jQuery) node = node[0];\n  return BDV2.getInternalInstance(node);\n}; // Gets data\n\n\nBdApi.loadData = function (pluginName, key) {\n  return DataStore.getPluginData(pluginName, key);\n};\n\nBdApi.getData = BdApi.loadData; // Sets data\n\nBdApi.saveData = function (pluginName, key, data) {\n  return DataStore.setPluginData(pluginName, key, data);\n};\n\nBdApi.setData = BdApi.saveData; // Deletes data\n\nBdApi.deleteData = function (pluginName, key) {\n  return DataStore.deletePluginData(pluginName, key);\n}; // Patches other functions\n\n\nBdApi.monkeyPatch = function (what, methodName, options) {\n  return Utils.monkeyPatch(what, methodName, options);\n}; // Event when element is removed\n\n\nBdApi.onRemoved = function (node, callback) {\n  return Utils.onRemoved(node, callback);\n}; // Wraps function in try..catch\n\n\nBdApi.suppressErrors = function (method, message) {\n  return Utils.suppressErrors(method, message);\n}; // Tests for valid JSON\n\n\nBdApi.testJSON = function (data) {\n  return Utils.testJSON(data);\n};\n\nBdApi.isPluginEnabled = function (name) {\n  return !!pluginCookie[name];\n};\n\nBdApi.isThemeEnabled = function (name) {\n  return !!themeCookie[name];\n};\n\nBdApi.isSettingEnabled = function (id) {\n  return !!settingsCookie[id];\n};\n\nBdApi.enableSetting = function (id) {\n  return settingsPanel.onChange(id, true);\n};\n\nBdApi.disableSetting = function (id) {\n  return settingsPanel.onChange(id, false);\n};\n\nBdApi.toggleSetting = function (id) {\n  return settingsPanel.onChange(id, !settingsCookie[id]);\n}; // Gets data\n\n\nBdApi.getBDData = function (key) {\n  return DataStore.getBDData(key);\n}; // Sets data\n\n\nBdApi.setBDData = function (key, data) {\n  return DataStore.setBDData(key, data);\n};\n\nconst makeAddonAPI = (cookie, list, manager) => new class AddonAPI {\n  get folder() {\n    return manager.folder;\n  }\n\n  isEnabled(name) {\n    return !!cookie[name];\n  }\n\n  enable(name) {\n    return manager.enable(name);\n  }\n\n  disable(name) {\n    return manager.disable(name);\n  }\n\n  toggle(name) {\n    if (cookie[name]) this.disable(name);else this.enable(name);\n  }\n\n  reload(name) {\n    return manager.reload(name);\n  }\n\n  get(name) {\n    if (list.hasOwnProperty(name)) {\n      if (list[name].plugin) return list[name].plugin;\n      return list[name];\n    }\n\n    return null;\n  }\n\n  getAll() {\n    return Object.keys(list).map(k => this.get(k)).filter(a => a);\n  }\n\n}();\n\nBdApi.Plugins = makeAddonAPI(pluginCookie, bdplugins, pluginModule);\nBdApi.Themes = makeAddonAPI(themeCookie, bdthemes, themeModule);\nexport default BdApi;"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/modules/bdApi.js\n"); + +/***/ }), + +/***/ "./src/modules/bdEvents.js": +/*!*********************************!*\ + !*** ./src/modules/bdEvents.js ***! + \*********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* BDEvents */\nconst EventEmitter = __webpack_require__(/*! events */ \"events\");\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class BDEvents extends EventEmitter {\n dispatch(eventName, ...args) {\n this.emit(eventName, ...args);\n }\n\n off(eventName, eventAction) {\n this.removeListener(eventName, eventAction);\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbW9kdWxlcy9iZEV2ZW50cy5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvbW9kdWxlcy9iZEV2ZW50cy5qcz84ZjI1Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIEJERXZlbnRzICovXG5jb25zdCBFdmVudEVtaXR0ZXIgPSByZXF1aXJlKFwiZXZlbnRzXCIpO1xuXG5leHBvcnQgZGVmYXVsdCBuZXcgY2xhc3MgQkRFdmVudHMgZXh0ZW5kcyBFdmVudEVtaXR0ZXIge1xuICBkaXNwYXRjaChldmVudE5hbWUsIC4uLmFyZ3MpIHtcbiAgICB0aGlzLmVtaXQoZXZlbnROYW1lLCAuLi5hcmdzKTtcbiAgfVxuXG4gIG9mZihldmVudE5hbWUsIGV2ZW50QWN0aW9uKSB7XG4gICAgdGhpcy5yZW1vdmVMaXN0ZW5lcihldmVudE5hbWUsIGV2ZW50QWN0aW9uKTtcbiAgfVxuXG59KCk7Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/modules/bdEvents.js\n"); + +/***/ }), + +/***/ "./src/modules/classNormalizer.js": +/*!****************************************!*\ + !*** ./src/modules/classNormalizer.js ***! + \****************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _webpackModules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./webpackModules */ \"./src/modules/webpackModules.js\");\n\nconst normalizedPrefix = \"da\";\nconst randClass = new RegExp(`^(?!${normalizedPrefix}-)((?:[A-Za-z]|[0-9]|-)+)-(?:[A-Za-z]|[0-9]|-|_){6}$`);\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class ClassNormalizer {\n stop() {\n if (!this.hasPatched) return;\n this.unpatchClassModules(_webpackModules__WEBPACK_IMPORTED_MODULE_0__[\"default\"].findAll(this.moduleFilter.bind(this)));\n this.revertElement(document.querySelector(\"#app-mount\"));\n this.hasPatched = false;\n }\n\n start() {\n if (this.hasPatched) return;\n this.patchClassModules(_webpackModules__WEBPACK_IMPORTED_MODULE_0__[\"default\"].findAll(this.moduleFilter.bind(this)));\n this.normalizeElement(document.querySelector(\"#app-mount\"));\n this.hasPatched = true;\n this.patchDOMMethods();\n }\n\n patchClassModules(modules) {\n for (const module of modules) {\n this.patchClassModule(normalizedPrefix, module);\n }\n }\n\n unpatchClassModules(modules) {\n for (const module of modules) {\n this.unpatchClassModule(normalizedPrefix, module);\n }\n }\n\n shouldIgnore(value) {\n if (!isNaN(value)) return true;\n if (value.endsWith(\"px\") || value.endsWith(\"ch\") || value.endsWith(\"em\") || value.endsWith(\"ms\")) return true;\n if (value.startsWith(\"layerContainer-\")) return true;\n if (value.startsWith(\"#\") && (value.length == 7 || value.length == 4)) return true;\n if (value.includes(\"calc(\") || value.includes(\"rgba\")) return true;\n return false;\n }\n\n moduleFilter(module) {\n if (typeof module !== \"object\" || Array.isArray(module)) return false;\n if (module.__esModule) return false;\n if (!Object.keys(module).length) return false;\n\n for (const baseClassName in module) {\n const value = module[baseClassName];\n if (typeof value !== \"string\") return false;\n if (this.shouldIgnore(value)) continue;\n if (value.split(\"-\").length === 1) return false;\n if (!randClass.test(value.split(\" \")[0])) return false;\n }\n\n return true;\n }\n\n patchClassModule(componentName, classNames) {\n for (const baseClassName in classNames) {\n const value = classNames[baseClassName];\n if (this.shouldIgnore(value)) continue;\n const classList = value.split(\" \");\n\n for (const normalClass of classList) {\n const match = normalClass.match(randClass);\n if (!match || !match.length || match.length < 2) continue; // Shouldn't ever happen since they passed the moduleFilter, but you never know\n\n const camelCase = match[1].split(\"-\").map((s, i) => i ? s[0].toUpperCase() + s.slice(1) : s).join(\"\");\n classNames[baseClassName] += ` ${componentName}-${camelCase}`;\n }\n }\n }\n\n unpatchClassModule(componentName, classNames) {\n for (const baseClassName in classNames) {\n const value = classNames[baseClassName];\n if (this.shouldIgnore(value)) continue;\n let newString = \"\";\n const classList = value.split(\" \");\n\n for (const normalClass of classList) {\n if (normalClass.startsWith(`${componentName}-`)) continue;\n newString += ` ${normalClass}`;\n }\n\n classNames[baseClassName] = newString.trim();\n }\n }\n\n normalizeElement(element) {\n if (!(element instanceof Element)) return;\n const classes = element.classList;\n\n for (let c = 0, clen = classes.length; c < clen; c++) {\n if (!randClass.test(classes[c])) continue;\n const match = classes[c].match(randClass)[1];\n const newClass = match.split(\"-\").map((s, i) => i ? s[0].toUpperCase() + s.slice(1) : s).join(\"\");\n element.classList.add(`${normalizedPrefix}-${newClass}`);\n }\n\n for (const child of element.children) this.normalizeElement(child);\n }\n\n revertElement(element) {\n if (!(element instanceof Element)) return;\n if (element.children && element.children.length) this.revertElement(element.children[0]);\n if (element.nextElementSibling) this.revertElement(element.nextElementSibling);\n const classes = element.classList;\n const toRemove = [];\n\n for (let c = 0; c < classes.length; c++) {\n if (classes[c].startsWith(`${normalizedPrefix}-`)) toRemove.push(classes[c]);\n }\n\n element.classList.remove(...toRemove);\n }\n\n patchDOMMethods() {\n const contains = DOMTokenList.prototype.contains;\n\n DOMTokenList.prototype.contains = function (token) {\n // const tokens = token.split(\" \");\n return Reflect.apply(contains, this, [token.split(\" \")[0]]); // return tokens.every(t => contains.call(this, t));\n };\n\n const add = DOMTokenList.prototype.add;\n\n DOMTokenList.prototype.add = function (...tokens) {\n for (let t = 0; t < tokens.length; t++) {\n tokens[t] = tokens[t].split(\" \")[0];\n }\n\n return Reflect.apply(add, this, tokens);\n };\n\n const remove = DOMTokenList.prototype.remove;\n\n DOMTokenList.prototype.remove = function (...tokens) {\n for (let t = 0; t < tokens.length; t++) {\n tokens[t] = tokens[t].split(\" \")[0];\n }\n\n return Reflect.apply(remove, this, tokens);\n };\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/modules/classNormalizer.js.js","sources":["webpack://BetterDiscord/./src/modules/classNormalizer.js?bf19"],"sourcesContent":["import WebpackModules from \"./webpackModules\";\nconst normalizedPrefix = \"da\";\nconst randClass = new RegExp(`^(?!${normalizedPrefix}-)((?:[A-Za-z]|[0-9]|-)+)-(?:[A-Za-z]|[0-9]|-|_){6}$`);\nexport default new class ClassNormalizer {\n  stop() {\n    if (!this.hasPatched) return;\n    this.unpatchClassModules(WebpackModules.findAll(this.moduleFilter.bind(this)));\n    this.revertElement(document.querySelector(\"#app-mount\"));\n    this.hasPatched = false;\n  }\n\n  start() {\n    if (this.hasPatched) return;\n    this.patchClassModules(WebpackModules.findAll(this.moduleFilter.bind(this)));\n    this.normalizeElement(document.querySelector(\"#app-mount\"));\n    this.hasPatched = true;\n    this.patchDOMMethods();\n  }\n\n  patchClassModules(modules) {\n    for (const module of modules) {\n      this.patchClassModule(normalizedPrefix, module);\n    }\n  }\n\n  unpatchClassModules(modules) {\n    for (const module of modules) {\n      this.unpatchClassModule(normalizedPrefix, module);\n    }\n  }\n\n  shouldIgnore(value) {\n    if (!isNaN(value)) return true;\n    if (value.endsWith(\"px\") || value.endsWith(\"ch\") || value.endsWith(\"em\") || value.endsWith(\"ms\")) return true;\n    if (value.startsWith(\"layerContainer-\")) return true;\n    if (value.startsWith(\"#\") && (value.length == 7 || value.length == 4)) return true;\n    if (value.includes(\"calc(\") || value.includes(\"rgba\")) return true;\n    return false;\n  }\n\n  moduleFilter(module) {\n    if (typeof module !== \"object\" || Array.isArray(module)) return false;\n    if (module.__esModule) return false;\n    if (!Object.keys(module).length) return false;\n\n    for (const baseClassName in module) {\n      const value = module[baseClassName];\n      if (typeof value !== \"string\") return false;\n      if (this.shouldIgnore(value)) continue;\n      if (value.split(\"-\").length === 1) return false;\n      if (!randClass.test(value.split(\" \")[0])) return false;\n    }\n\n    return true;\n  }\n\n  patchClassModule(componentName, classNames) {\n    for (const baseClassName in classNames) {\n      const value = classNames[baseClassName];\n      if (this.shouldIgnore(value)) continue;\n      const classList = value.split(\" \");\n\n      for (const normalClass of classList) {\n        const match = normalClass.match(randClass);\n        if (!match || !match.length || match.length < 2) continue; // Shouldn't ever happen since they passed the moduleFilter, but you never know\n\n        const camelCase = match[1].split(\"-\").map((s, i) => i ? s[0].toUpperCase() + s.slice(1) : s).join(\"\");\n        classNames[baseClassName] += ` ${componentName}-${camelCase}`;\n      }\n    }\n  }\n\n  unpatchClassModule(componentName, classNames) {\n    for (const baseClassName in classNames) {\n      const value = classNames[baseClassName];\n      if (this.shouldIgnore(value)) continue;\n      let newString = \"\";\n      const classList = value.split(\" \");\n\n      for (const normalClass of classList) {\n        if (normalClass.startsWith(`${componentName}-`)) continue;\n        newString += ` ${normalClass}`;\n      }\n\n      classNames[baseClassName] = newString.trim();\n    }\n  }\n\n  normalizeElement(element) {\n    if (!(element instanceof Element)) return;\n    const classes = element.classList;\n\n    for (let c = 0, clen = classes.length; c < clen; c++) {\n      if (!randClass.test(classes[c])) continue;\n      const match = classes[c].match(randClass)[1];\n      const newClass = match.split(\"-\").map((s, i) => i ? s[0].toUpperCase() + s.slice(1) : s).join(\"\");\n      element.classList.add(`${normalizedPrefix}-${newClass}`);\n    }\n\n    for (const child of element.children) this.normalizeElement(child);\n  }\n\n  revertElement(element) {\n    if (!(element instanceof Element)) return;\n    if (element.children && element.children.length) this.revertElement(element.children[0]);\n    if (element.nextElementSibling) this.revertElement(element.nextElementSibling);\n    const classes = element.classList;\n    const toRemove = [];\n\n    for (let c = 0; c < classes.length; c++) {\n      if (classes[c].startsWith(`${normalizedPrefix}-`)) toRemove.push(classes[c]);\n    }\n\n    element.classList.remove(...toRemove);\n  }\n\n  patchDOMMethods() {\n    const contains = DOMTokenList.prototype.contains;\n\n    DOMTokenList.prototype.contains = function (token) {\n      // const tokens = token.split(\" \");\n      return Reflect.apply(contains, this, [token.split(\" \")[0]]); // return tokens.every(t => contains.call(this, t));\n    };\n\n    const add = DOMTokenList.prototype.add;\n\n    DOMTokenList.prototype.add = function (...tokens) {\n      for (let t = 0; t < tokens.length; t++) {\n        tokens[t] = tokens[t].split(\" \")[0];\n      }\n\n      return Reflect.apply(add, this, tokens);\n    };\n\n    const remove = DOMTokenList.prototype.remove;\n\n    DOMTokenList.prototype.remove = function (...tokens) {\n      for (let t = 0; t < tokens.length; t++) {\n        tokens[t] = tokens[t].split(\" \")[0];\n      }\n\n      return Reflect.apply(remove, this, tokens);\n    };\n  }\n\n}();"],"mappings":"AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/modules/classNormalizer.js\n"); + +/***/ }), + +/***/ "./src/modules/coloredText.js": +/*!************************************!*\ + !*** ./src/modules/coloredText.js ***! + \************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _v2__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class ColoredText {\n injectColoredText() {\n if (this.cancelColoredText) return;\n if (!_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].MessageComponent) return;\n this.cancelColoredText = _utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].monkeyPatch(_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].MessageComponent, \"default\", {\n before: data => {\n const props = data.methodArguments[0];\n if (!props || !props.childrenMessageContent) return;\n const messageContent = props.childrenMessageContent;\n if (!messageContent.type || !messageContent.type.type || messageContent.type.type.displayName != \"MessageContent\") return;\n const originalType = messageContent.type.type;\n if (originalType.__originalMethod) return; // Don't patch again\n\n messageContent.type.type = function (props) {\n const returnValue = originalType(props);\n const roleColor = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-gs-7\"] ? props.message.colorString || \"\" : \"\";\n returnValue.props.style = {\n color: roleColor\n };\n return returnValue;\n };\n\n messageContent.type.type.__originalMethod = originalType;\n Object.assign(messageContent.type.type, originalType);\n }\n });\n }\n\n removeColoredText() {\n let classNameMarkup = BDModules.get(e => e.markup)[0].markup;\n document.querySelectorAll(\".\" + classNameMarkup.split(\" \")[0]).forEach(elem => {\n elem.style.setProperty(\"color\", \"\");\n });\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbW9kdWxlcy9jb2xvcmVkVGV4dC5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvbW9kdWxlcy9jb2xvcmVkVGV4dC5qcz9lMjk3Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHNldHRpbmdzQ29va2llIH0gZnJvbSBcIi4uLzBnbG9iYWxzXCI7XG5pbXBvcnQgQkRWMiBmcm9tIFwiLi92MlwiO1xuaW1wb3J0IFV0aWxzIGZyb20gXCIuL3V0aWxzXCI7XG5leHBvcnQgZGVmYXVsdCBuZXcgY2xhc3MgQ29sb3JlZFRleHQge1xuICBpbmplY3RDb2xvcmVkVGV4dCgpIHtcbiAgICBpZiAodGhpcy5jYW5jZWxDb2xvcmVkVGV4dCkgcmV0dXJuO1xuICAgIGlmICghQkRWMi5NZXNzYWdlQ29tcG9uZW50KSByZXR1cm47XG4gICAgdGhpcy5jYW5jZWxDb2xvcmVkVGV4dCA9IFV0aWxzLm1vbmtleVBhdGNoKEJEVjIuTWVzc2FnZUNvbXBvbmVudCwgXCJkZWZhdWx0XCIsIHtcbiAgICAgIGJlZm9yZTogZGF0YSA9PiB7XG4gICAgICAgIGNvbnN0IHByb3BzID0gZGF0YS5tZXRob2RBcmd1bWVudHNbMF07XG4gICAgICAgIGlmICghcHJvcHMgfHwgIXByb3BzLmNoaWxkcmVuTWVzc2FnZUNvbnRlbnQpIHJldHVybjtcbiAgICAgICAgY29uc3QgbWVzc2FnZUNvbnRlbnQgPSBwcm9wcy5jaGlsZHJlbk1lc3NhZ2VDb250ZW50O1xuICAgICAgICBpZiAoIW1lc3NhZ2VDb250ZW50LnR5cGUgfHwgIW1lc3NhZ2VDb250ZW50LnR5cGUudHlwZSB8fCBtZXNzYWdlQ29udGVudC50eXBlLnR5cGUuZGlzcGxheU5hbWUgIT0gXCJNZXNzYWdlQ29udGVudFwiKSByZXR1cm47XG4gICAgICAgIGNvbnN0IG9yaWdpbmFsVHlwZSA9IG1lc3NhZ2VDb250ZW50LnR5cGUudHlwZTtcbiAgICAgICAgaWYgKG9yaWdpbmFsVHlwZS5fX29yaWdpbmFsTWV0aG9kKSByZXR1cm47IC8vIERvbid0IHBhdGNoIGFnYWluXG5cbiAgICAgICAgbWVzc2FnZUNvbnRlbnQudHlwZS50eXBlID0gZnVuY3Rpb24gKHByb3BzKSB7XG4gICAgICAgICAgY29uc3QgcmV0dXJuVmFsdWUgPSBvcmlnaW5hbFR5cGUocHJvcHMpO1xuICAgICAgICAgIGNvbnN0IHJvbGVDb2xvciA9IHNldHRpbmdzQ29va2llW1wiYmRhLWdzLTdcIl0gPyBwcm9wcy5tZXNzYWdlLmNvbG9yU3RyaW5nIHx8IFwiXCIgOiBcIlwiO1xuICAgICAgICAgIHJldHVyblZhbHVlLnByb3BzLnN0eWxlID0ge1xuICAgICAgICAgICAgY29sb3I6IHJvbGVDb2xvclxuICAgICAgICAgIH07XG4gICAgICAgICAgcmV0dXJuIHJldHVyblZhbHVlO1xuICAgICAgICB9O1xuXG4gICAgICAgIG1lc3NhZ2VDb250ZW50LnR5cGUudHlwZS5fX29yaWdpbmFsTWV0aG9kID0gb3JpZ2luYWxUeXBlO1xuICAgICAgICBPYmplY3QuYXNzaWduKG1lc3NhZ2VDb250ZW50LnR5cGUudHlwZSwgb3JpZ2luYWxUeXBlKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIHJlbW92ZUNvbG9yZWRUZXh0KCkge1xuICAgIGxldCBjbGFzc05hbWVNYXJrdXAgPSBCRE1vZHVsZXMuZ2V0KGUgPT4gZS5tYXJrdXApWzBdLm1hcmt1cDtcbiAgICBkb2N1bWVudC5xdWVyeVNlbGVjdG9yQWxsKFwiLlwiICsgY2xhc3NOYW1lTWFya3VwLnNwbGl0KFwiIFwiKVswXSkuZm9yRWFjaChlbGVtID0+IHtcbiAgICAgIGVsZW0uc3R5bGUuc2V0UHJvcGVydHkoXCJjb2xvclwiLCBcIlwiKTtcbiAgICB9KTtcbiAgfVxuXG59KCk7Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/modules/coloredText.js\n"); + +/***/ }), + +/***/ "./src/modules/contentManager.js": +/*!***************************************!*\ + !*** ./src/modules/contentManager.js ***! + \***************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _pluginModule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./pluginModule */ \"./src/modules/pluginModule.js\");\n/* harmony import */ var _themeModule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./themeModule */ \"./src/modules/themeModule.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\nconst __non_webpack_require__ = window.require;\n\n\n\n\n\nconst path = __webpack_require__(/*! path */ \"path\");\n\nconst fs = __webpack_require__(/*! fs */ \"fs\");\n\nconst Module = __webpack_require__(/*! module */ \"module\").Module;\n\nModule.globalPaths.push(path.resolve(__webpack_require__(/*! electron */ \"electron\").remote.app.getAppPath(), \"node_modules\"));\n\nclass MetaError extends Error {\n constructor(message) {\n super(message);\n this.name = \"MetaError\";\n }\n\n}\n\nconst originalJSRequire = Module._extensions[\".js\"];\nconst originalCSSRequire = Module._extensions[\".css\"] ? Module._extensions[\".css\"] : () => {\n return null;\n};\nconst splitRegex = /[^\\S\\r\\n]*?(?:\\r\\n|\\n)[^\\S\\r\\n]*?\\*[^\\S\\r\\n]?/;\nconst escapedAtRegex = /^\\\\@/;\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class ContentManager {\n constructor() {\n this.timeCache = {};\n this.watchers = {};\n Module._extensions[\".js\"] = this.getContentRequire(\"plugin\");\n Module._extensions[\".css\"] = this.getContentRequire(\"theme\");\n }\n\n get pluginsFolder() {\n return this._pluginsFolder || (this._pluginsFolder = fs.realpathSync(path.resolve(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].dataPath + \"plugins/\")));\n }\n\n get themesFolder() {\n return this._themesFolder || (this._themesFolder = fs.realpathSync(path.resolve(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].dataPath + \"themes/\")));\n }\n\n watchContent(contentType) {\n if (this.watchers[contentType]) return;\n const isPlugin = contentType === \"plugin\";\n const baseFolder = isPlugin ? this.pluginsFolder : this.themesFolder;\n const fileEnding = isPlugin ? \".plugin.js\" : \".theme.css\";\n this.watchers[contentType] = fs.watch(baseFolder, {\n persistent: false\n }, async (eventType, filename) => {\n if (!eventType || !filename || !filename.endsWith(fileEnding)) return;\n await new Promise(r => setTimeout(r, 50));\n\n try {\n fs.statSync(path.resolve(baseFolder, filename));\n } catch (err) {\n if (err.code !== \"ENOENT\") return;\n delete this.timeCache[filename];\n if (isPlugin) return _pluginModule__WEBPACK_IMPORTED_MODULE_1__[\"default\"].unloadPlugin(filename);\n return _themeModule__WEBPACK_IMPORTED_MODULE_2__[\"default\"].unloadTheme(filename);\n }\n\n if (!fs.statSync(path.resolve(baseFolder, filename)).isFile()) return;\n const stats = fs.statSync(path.resolve(baseFolder, filename));\n if (!stats || !stats.mtime || !stats.mtime.getTime()) return;\n if (typeof stats.mtime.getTime() !== \"number\") return;\n if (this.timeCache[filename] == stats.mtime.getTime()) return;\n this.timeCache[filename] = stats.mtime.getTime();\n\n if (eventType == \"rename\") {\n if (isPlugin) _pluginModule__WEBPACK_IMPORTED_MODULE_1__[\"default\"].loadPlugin(filename);else _themeModule__WEBPACK_IMPORTED_MODULE_2__[\"default\"].loadTheme(filename);\n }\n\n if (eventType == \"change\") {\n if (isPlugin) _pluginModule__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reloadPlugin(filename);else _themeModule__WEBPACK_IMPORTED_MODULE_2__[\"default\"].reloadTheme(filename);\n }\n });\n }\n\n unwatchContent(contentType) {\n if (!this.watchers[contentType]) return;\n this.watchers[contentType].close();\n delete this.watchers[contentType];\n }\n\n extractMeta(content) {\n const firstLine = content.split(\"\\n\")[0];\n const hasOldMeta = firstLine.includes(\"//META\");\n if (hasOldMeta) return this.parseOldMeta(content);\n const hasNewMeta = firstLine.includes(\"/**\");\n if (hasNewMeta) return this.parseNewMeta(content);\n throw new MetaError(\"META was not found.\");\n }\n\n parseOldMeta(content) {\n const meta = content.split(\"\\n\")[0];\n const rawMeta = meta.substring(meta.lastIndexOf(\"//META\") + 6, meta.lastIndexOf(\"*//\"));\n if (meta.indexOf(\"META\") < 0) throw new MetaError(\"META was not found.\");\n const parsed = _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].testJSON(rawMeta);\n if (!parsed) throw new MetaError(\"META could not be parsed.\");\n if (!parsed.name) throw new MetaError(\"META missing name data.\");\n parsed.format = \"json\";\n return parsed;\n }\n\n parseNewMeta(content) {\n const block = content.split(\"/**\", 2)[1].split(\"*/\", 1)[0];\n const out = {};\n let field = \"\";\n let accum = \"\";\n\n for (const line of block.split(splitRegex)) {\n if (line.length === 0) continue;\n\n if (line.charAt(0) === \"@\" && line.charAt(1) !== \" \") {\n out[field] = accum;\n const l = line.indexOf(\" \");\n field = line.substr(1, l - 1);\n accum = line.substr(l + 1);\n } else {\n accum += \" \" + line.replace(\"\\\\n\", \"\\n\").replace(escapedAtRegex, \"@\");\n }\n }\n\n out[field] = accum.trim();\n delete out[\"\"];\n out.format = \"jsdoc\";\n return out;\n }\n\n getContentRequire(type) {\n const isPlugin = type === \"plugin\";\n const self = this;\n const originalRequire = isPlugin ? originalJSRequire : originalCSSRequire;\n return function (module, filename) {\n const baseFolder = isPlugin ? self.pluginsFolder : self.themesFolder;\n const possiblePath = path.resolve(baseFolder, path.basename(filename));\n if (!fs.existsSync(possiblePath) || filename !== fs.realpathSync(possiblePath)) return Reflect.apply(originalRequire, this, arguments);\n let content = fs.readFileSync(filename, \"utf8\");\n content = _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].stripBOM(content);\n const stats = fs.statSync(filename);\n const meta = self.extractMeta(content);\n meta.filename = path.basename(filename);\n meta.added = stats.atimeMs;\n meta.modified = stats.mtimeMs;\n meta.size = stats.size;\n\n if (!isPlugin) {\n meta.css = content;\n if (meta.format == \"json\") meta.css = meta.css.split(\"\\n\").slice(1).join(\"\\n\");\n content = `module.exports = ${JSON.stringify(meta)};`;\n }\n\n if (isPlugin) {\n module._compile(content, module.filename);\n\n const didExport = !_utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].isEmpty(module.exports);\n\n if (didExport) {\n meta.type = module.exports;\n module.exports = meta;\n content = \"\";\n } else {\n content += `\\nmodule.exports = ${JSON.stringify(meta)};\\nmodule.exports.type = ${meta.exports || meta.name};`;\n }\n }\n\n module._compile(content, filename);\n };\n }\n\n makePlaceholderPlugin(data) {\n return {\n plugin: {\n start: () => {},\n getName: () => {\n return data.name || data.filename;\n },\n getAuthor: () => {\n return \"???\";\n },\n getDescription: () => {\n return data.message ? data.message : \"This plugin was unable to be loaded. Check the author's page for updates.\";\n },\n getVersion: () => {\n return \"???\";\n }\n },\n name: data.name || data.filename,\n filename: data.filename,\n source: data.source ? data.source : \"\",\n website: data.website ? data.website : \"\"\n };\n }\n\n loadContent(filename, type) {\n if (typeof filename === \"undefined\" || typeof type === \"undefined\") return;\n const isPlugin = type === \"plugin\";\n const baseFolder = isPlugin ? this.pluginsFolder : this.themesFolder;\n\n try {\n __non_webpack_require__(path.resolve(baseFolder, filename));\n } catch (error) {\n return {\n name: filename,\n file: filename,\n message: \"Could not be compiled.\",\n error: {\n message: error.message,\n stack: error.stack\n }\n };\n }\n\n const content = __non_webpack_require__(path.resolve(baseFolder, filename));\n\n if (!content.name) return {\n name: filename,\n file: filename,\n message: \"Cannot escape the ID.\",\n error: {\n message: \"Cannot read property 'replace' of undefined\",\n stack: \"Cannot read property 'replace' of undefined\"\n }\n };\n content.id = _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].escapeID(content.name);\n\n if (isPlugin) {\n if (!content.type) return;\n\n try {\n content.plugin = new content.type();\n delete _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][content.plugin.getName()];\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][content.plugin.getName()] = content;\n } catch (error) {\n return {\n name: filename,\n file: filename,\n message: \"Could not be constructed.\",\n error: {\n message: error.message,\n stack: error.stack\n }\n };\n }\n } else {\n delete _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][content.name];\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][content.name] = content;\n }\n }\n\n unloadContent(filename, type) {\n if (typeof filename === \"undefined\" || typeof type === \"undefined\") return;\n const isPlugin = type === \"plugin\";\n const baseFolder = isPlugin ? this.pluginsFolder : this.themesFolder;\n\n try {\n delete __non_webpack_require__.cache[__non_webpack_require__.resolve(path.resolve(baseFolder, filename))];\n } catch (err) {\n return {\n name: filename,\n file: filename,\n message: \"Could not be unloaded.\",\n error: {\n message: err.message,\n stack: err.stack\n }\n };\n }\n }\n\n isLoaded(filename, type) {\n const isPlugin = type === \"plugin\";\n const baseFolder = isPlugin ? this.pluginsFolder : this.themesFolder;\n\n try {\n __non_webpack_require__.cache[__non_webpack_require__.resolve(path.resolve(baseFolder, filename))];\n } catch (err) {\n return false;\n }\n\n return true;\n }\n\n reloadContent(filename, type) {\n const cantUnload = this.unloadContent(filename, type);\n if (cantUnload) return cantUnload;\n return this.loadContent(filename, type);\n }\n\n loadNewContent(type) {\n const isPlugin = type === \"plugin\";\n const fileEnding = isPlugin ? \".plugin.js\" : \".theme.css\";\n const basedir = isPlugin ? this.pluginsFolder : this.themesFolder;\n const files = fs.readdirSync(basedir);\n const contentList = Object.values(isPlugin ? _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"] : _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"]);\n const removed = contentList.filter(t => !files.includes(t.filename)).map(c => isPlugin ? c.plugin.getName() : c.name);\n const added = files.filter(f => !contentList.find(t => t.filename == f) && f.endsWith(fileEnding) && fs.statSync(path.resolve(basedir, f)).isFile());\n return {\n added,\n removed\n };\n }\n\n loadAllContent(type) {\n const isPlugin = type === \"plugin\";\n const fileEnding = isPlugin ? \".plugin.js\" : \".theme.css\";\n const basedir = isPlugin ? this.pluginsFolder : this.themesFolder;\n const errors = [];\n const files = fs.readdirSync(basedir);\n\n for (const filename of files) {\n if (!fs.statSync(path.resolve(basedir, filename)).isFile() || !filename.endsWith(fileEnding)) continue;\n const error = this.loadContent(filename, type);\n if (error) errors.push(error);\n }\n\n return errors;\n }\n\n loadPlugins() {\n return this.loadAllContent(\"plugin\");\n }\n\n loadThemes() {\n return this.loadAllContent(\"theme\");\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/modules/contentManager.js.js","sources":["webpack://BetterDiscord/./src/modules/contentManager.js?4eb0"],"sourcesContent":["const __non_webpack_require__ = window.require;\nimport { bdConfig, bdplugins, bdthemes } from \"../0globals\";\nimport pluginModule from \"./pluginModule\";\nimport themeModule from \"./themeModule\";\nimport Utils from \"./utils\";\n\nconst path = require(\"path\");\n\nconst fs = require(\"fs\");\n\nconst Module = require(\"module\").Module;\n\nModule.globalPaths.push(path.resolve(require(\"electron\").remote.app.getAppPath(), \"node_modules\"));\n\nclass MetaError extends Error {\n  constructor(message) {\n    super(message);\n    this.name = \"MetaError\";\n  }\n\n}\n\nconst originalJSRequire = Module._extensions[\".js\"];\nconst originalCSSRequire = Module._extensions[\".css\"] ? Module._extensions[\".css\"] : () => {\n  return null;\n};\nconst splitRegex = /[^\\S\\r\\n]*?(?:\\r\\n|\\n)[^\\S\\r\\n]*?\\*[^\\S\\r\\n]?/;\nconst escapedAtRegex = /^\\\\@/;\nexport default new class ContentManager {\n  constructor() {\n    this.timeCache = {};\n    this.watchers = {};\n    Module._extensions[\".js\"] = this.getContentRequire(\"plugin\");\n    Module._extensions[\".css\"] = this.getContentRequire(\"theme\");\n  }\n\n  get pluginsFolder() {\n    return this._pluginsFolder || (this._pluginsFolder = fs.realpathSync(path.resolve(bdConfig.dataPath + \"plugins/\")));\n  }\n\n  get themesFolder() {\n    return this._themesFolder || (this._themesFolder = fs.realpathSync(path.resolve(bdConfig.dataPath + \"themes/\")));\n  }\n\n  watchContent(contentType) {\n    if (this.watchers[contentType]) return;\n    const isPlugin = contentType === \"plugin\";\n    const baseFolder = isPlugin ? this.pluginsFolder : this.themesFolder;\n    const fileEnding = isPlugin ? \".plugin.js\" : \".theme.css\";\n    this.watchers[contentType] = fs.watch(baseFolder, {\n      persistent: false\n    }, async (eventType, filename) => {\n      if (!eventType || !filename || !filename.endsWith(fileEnding)) return;\n      await new Promise(r => setTimeout(r, 50));\n\n      try {\n        fs.statSync(path.resolve(baseFolder, filename));\n      } catch (err) {\n        if (err.code !== \"ENOENT\") return;\n        delete this.timeCache[filename];\n        if (isPlugin) return pluginModule.unloadPlugin(filename);\n        return themeModule.unloadTheme(filename);\n      }\n\n      if (!fs.statSync(path.resolve(baseFolder, filename)).isFile()) return;\n      const stats = fs.statSync(path.resolve(baseFolder, filename));\n      if (!stats || !stats.mtime || !stats.mtime.getTime()) return;\n      if (typeof stats.mtime.getTime() !== \"number\") return;\n      if (this.timeCache[filename] == stats.mtime.getTime()) return;\n      this.timeCache[filename] = stats.mtime.getTime();\n\n      if (eventType == \"rename\") {\n        if (isPlugin) pluginModule.loadPlugin(filename);else themeModule.loadTheme(filename);\n      }\n\n      if (eventType == \"change\") {\n        if (isPlugin) pluginModule.reloadPlugin(filename);else themeModule.reloadTheme(filename);\n      }\n    });\n  }\n\n  unwatchContent(contentType) {\n    if (!this.watchers[contentType]) return;\n    this.watchers[contentType].close();\n    delete this.watchers[contentType];\n  }\n\n  extractMeta(content) {\n    const firstLine = content.split(\"\\n\")[0];\n    const hasOldMeta = firstLine.includes(\"//META\");\n    if (hasOldMeta) return this.parseOldMeta(content);\n    const hasNewMeta = firstLine.includes(\"/**\");\n    if (hasNewMeta) return this.parseNewMeta(content);\n    throw new MetaError(\"META was not found.\");\n  }\n\n  parseOldMeta(content) {\n    const meta = content.split(\"\\n\")[0];\n    const rawMeta = meta.substring(meta.lastIndexOf(\"//META\") + 6, meta.lastIndexOf(\"*//\"));\n    if (meta.indexOf(\"META\") < 0) throw new MetaError(\"META was not found.\");\n    const parsed = Utils.testJSON(rawMeta);\n    if (!parsed) throw new MetaError(\"META could not be parsed.\");\n    if (!parsed.name) throw new MetaError(\"META missing name data.\");\n    parsed.format = \"json\";\n    return parsed;\n  }\n\n  parseNewMeta(content) {\n    const block = content.split(\"/**\", 2)[1].split(\"*/\", 1)[0];\n    const out = {};\n    let field = \"\";\n    let accum = \"\";\n\n    for (const line of block.split(splitRegex)) {\n      if (line.length === 0) continue;\n\n      if (line.charAt(0) === \"@\" && line.charAt(1) !== \" \") {\n        out[field] = accum;\n        const l = line.indexOf(\" \");\n        field = line.substr(1, l - 1);\n        accum = line.substr(l + 1);\n      } else {\n        accum += \" \" + line.replace(\"\\\\n\", \"\\n\").replace(escapedAtRegex, \"@\");\n      }\n    }\n\n    out[field] = accum.trim();\n    delete out[\"\"];\n    out.format = \"jsdoc\";\n    return out;\n  }\n\n  getContentRequire(type) {\n    const isPlugin = type === \"plugin\";\n    const self = this;\n    const originalRequire = isPlugin ? originalJSRequire : originalCSSRequire;\n    return function (module, filename) {\n      const baseFolder = isPlugin ? self.pluginsFolder : self.themesFolder;\n      const possiblePath = path.resolve(baseFolder, path.basename(filename));\n      if (!fs.existsSync(possiblePath) || filename !== fs.realpathSync(possiblePath)) return Reflect.apply(originalRequire, this, arguments);\n      let content = fs.readFileSync(filename, \"utf8\");\n      content = Utils.stripBOM(content);\n      const stats = fs.statSync(filename);\n      const meta = self.extractMeta(content);\n      meta.filename = path.basename(filename);\n      meta.added = stats.atimeMs;\n      meta.modified = stats.mtimeMs;\n      meta.size = stats.size;\n\n      if (!isPlugin) {\n        meta.css = content;\n        if (meta.format == \"json\") meta.css = meta.css.split(\"\\n\").slice(1).join(\"\\n\");\n        content = `module.exports = ${JSON.stringify(meta)};`;\n      }\n\n      if (isPlugin) {\n        module._compile(content, module.filename);\n\n        const didExport = !Utils.isEmpty(module.exports);\n\n        if (didExport) {\n          meta.type = module.exports;\n          module.exports = meta;\n          content = \"\";\n        } else {\n          content += `\\nmodule.exports = ${JSON.stringify(meta)};\\nmodule.exports.type = ${meta.exports || meta.name};`;\n        }\n      }\n\n      module._compile(content, filename);\n    };\n  }\n\n  makePlaceholderPlugin(data) {\n    return {\n      plugin: {\n        start: () => {},\n        getName: () => {\n          return data.name || data.filename;\n        },\n        getAuthor: () => {\n          return \"???\";\n        },\n        getDescription: () => {\n          return data.message ? data.message : \"This plugin was unable to be loaded. Check the author's page for updates.\";\n        },\n        getVersion: () => {\n          return \"???\";\n        }\n      },\n      name: data.name || data.filename,\n      filename: data.filename,\n      source: data.source ? data.source : \"\",\n      website: data.website ? data.website : \"\"\n    };\n  }\n\n  loadContent(filename, type) {\n    if (typeof filename === \"undefined\" || typeof type === \"undefined\") return;\n    const isPlugin = type === \"plugin\";\n    const baseFolder = isPlugin ? this.pluginsFolder : this.themesFolder;\n\n    try {\n      __non_webpack_require__(path.resolve(baseFolder, filename));\n    } catch (error) {\n      return {\n        name: filename,\n        file: filename,\n        message: \"Could not be compiled.\",\n        error: {\n          message: error.message,\n          stack: error.stack\n        }\n      };\n    }\n\n    const content = __non_webpack_require__(path.resolve(baseFolder, filename));\n\n    if (!content.name) return {\n      name: filename,\n      file: filename,\n      message: \"Cannot escape the ID.\",\n      error: {\n        message: \"Cannot read property 'replace' of undefined\",\n        stack: \"Cannot read property 'replace' of undefined\"\n      }\n    };\n    content.id = Utils.escapeID(content.name);\n\n    if (isPlugin) {\n      if (!content.type) return;\n\n      try {\n        content.plugin = new content.type();\n        delete bdplugins[content.plugin.getName()];\n        bdplugins[content.plugin.getName()] = content;\n      } catch (error) {\n        return {\n          name: filename,\n          file: filename,\n          message: \"Could not be constructed.\",\n          error: {\n            message: error.message,\n            stack: error.stack\n          }\n        };\n      }\n    } else {\n      delete bdthemes[content.name];\n      bdthemes[content.name] = content;\n    }\n  }\n\n  unloadContent(filename, type) {\n    if (typeof filename === \"undefined\" || typeof type === \"undefined\") return;\n    const isPlugin = type === \"plugin\";\n    const baseFolder = isPlugin ? this.pluginsFolder : this.themesFolder;\n\n    try {\n      delete __non_webpack_require__.cache[__non_webpack_require__.resolve(path.resolve(baseFolder, filename))];\n    } catch (err) {\n      return {\n        name: filename,\n        file: filename,\n        message: \"Could not be unloaded.\",\n        error: {\n          message: err.message,\n          stack: err.stack\n        }\n      };\n    }\n  }\n\n  isLoaded(filename, type) {\n    const isPlugin = type === \"plugin\";\n    const baseFolder = isPlugin ? this.pluginsFolder : this.themesFolder;\n\n    try {\n      __non_webpack_require__.cache[__non_webpack_require__.resolve(path.resolve(baseFolder, filename))];\n    } catch (err) {\n      return false;\n    }\n\n    return true;\n  }\n\n  reloadContent(filename, type) {\n    const cantUnload = this.unloadContent(filename, type);\n    if (cantUnload) return cantUnload;\n    return this.loadContent(filename, type);\n  }\n\n  loadNewContent(type) {\n    const isPlugin = type === \"plugin\";\n    const fileEnding = isPlugin ? \".plugin.js\" : \".theme.css\";\n    const basedir = isPlugin ? this.pluginsFolder : this.themesFolder;\n    const files = fs.readdirSync(basedir);\n    const contentList = Object.values(isPlugin ? bdplugins : bdthemes);\n    const removed = contentList.filter(t => !files.includes(t.filename)).map(c => isPlugin ? c.plugin.getName() : c.name);\n    const added = files.filter(f => !contentList.find(t => t.filename == f) && f.endsWith(fileEnding) && fs.statSync(path.resolve(basedir, f)).isFile());\n    return {\n      added,\n      removed\n    };\n  }\n\n  loadAllContent(type) {\n    const isPlugin = type === \"plugin\";\n    const fileEnding = isPlugin ? \".plugin.js\" : \".theme.css\";\n    const basedir = isPlugin ? this.pluginsFolder : this.themesFolder;\n    const errors = [];\n    const files = fs.readdirSync(basedir);\n\n    for (const filename of files) {\n      if (!fs.statSync(path.resolve(basedir, filename)).isFile() || !filename.endsWith(fileEnding)) continue;\n      const error = this.loadContent(filename, type);\n      if (error) errors.push(error);\n    }\n\n    return errors;\n  }\n\n  loadPlugins() {\n    return this.loadAllContent(\"plugin\");\n  }\n\n  loadThemes() {\n    return this.loadAllContent(\"theme\");\n  }\n\n}();"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/modules/contentManager.js\n"); + +/***/ }), + +/***/ "./src/modules/core.js": +/*!*****************************!*\ + !*** ./src/modules/core.js ***! + \*****************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _v2__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _settingsPanel__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./settingsPanel */ \"./src/modules/settingsPanel.js\");\n/* harmony import */ var _pluginModule__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./pluginModule */ \"./src/modules/pluginModule.js\");\n/* harmony import */ var _themeModule__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./themeModule */ \"./src/modules/themeModule.js\");\n/* harmony import */ var _dataStore__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./dataStore */ \"./src/modules/dataStore.js\");\n/* harmony import */ var _webpackModules__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./webpackModules */ \"./src/modules/webpackModules.js\");\n/* harmony import */ var _domtools__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./domtools */ \"./src/modules/domtools.js\");\n/* harmony import */ var _ui_bdLogo__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../ui/bdLogo */ \"./src/ui/bdLogo.js\");\n/* harmony import */ var _ui_tooltipWrap__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../ui/tooltipWrap */ \"./src/ui/tooltipWrap.js\");\n/* harmony import */ var _ui_lightcordLogo__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../ui/lightcordLogo */ \"./src/ui/lightcordLogo.js\");\n\n\n\n\n\n\n\n\n\n\n\n\n\nfunction Core() {// Object.assign(bdConfig, __non_webpack_require__(DataStore.configFile));\n // this.init();\n}\n\nCore.prototype.setConfig = function (config) {\n Object.assign(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"], config);\n};\n\nCore.prototype.init = async function () {\n if (!Array.prototype.flat) {\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].alert(\"Not Supported\", \"BetterDiscord v\" + _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bbdVersion\"] + \" does not support this old version (\" + _0globals__WEBPACK_IMPORTED_MODULE_0__[\"currentDiscordVersion\"] + \") of Discord. Please update your Discord installation before proceeding.\");\n return;\n }\n\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].version < _0globals__WEBPACK_IMPORTED_MODULE_0__[\"minSupportedVersion\"]) {\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].alert(\"Not Supported\", \"BetterDiscord v\" + _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].version + \" (your version)\" + \" is not supported by the latest js (\" + _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bbdVersion\"] + \").

Please download the latest version from GitHub\");\n return;\n }\n\n if (window.ED) {\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].alert(\"Not Supported\", \"BandagedBD does not work with EnhancedDiscord. Please uninstall one of them.\");\n return;\n }\n\n if (window.WebSocket && window.WebSocket.name && window.WebSocket.name.includes(\"Patched\")) {\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].alert(\"Not Supported\", \"BandagedBD does not work with Powercord. Please uninstall one of them.\");\n return;\n }\n\n const latestLocalVersion = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].updater ? _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].updater.LatestVersion : _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].latestVersion;\n\n if (latestLocalVersion > _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].version) {\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].showConfirmationModal(\"Update Available\", [`There is an update available for BandagedBD's Injector (${latestLocalVersion}).`, \"You can either update and restart now, or later.\"], {\n confirmText: \"Update Now\",\n cancelText: \"Maybe Later\",\n onConfirm: async () => {\n const onUpdateFailed = () => {\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].alert(\"Could Not Update\", `Unable to update automatically, please download the installer and reinstall normally.

Download Installer`);\n };\n\n try {\n const didUpdate = await this.updateInjector();\n if (!didUpdate) return onUpdateFailed();\n\n const app = __webpack_require__(/*! electron */ \"electron\").remote.app;\n\n app.relaunch();\n app.exit();\n } catch (err) {\n onUpdateFailed();\n }\n }\n });\n }\n\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"Startup\", \"Initializing Settings\");\n this.initSettings();\n await this.checkForGuilds();\n _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].initialize();\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"Startup\", \"Updating Settings\");\n _settingsPanel__WEBPACK_IMPORTED_MODULE_3__[\"default\"].initializeSettings();\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"Startup\", \"Loading Plugins\");\n _pluginModule__WEBPACK_IMPORTED_MODULE_4__[\"default\"].loadPlugins();\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"Startup\", \"Loading Themes\");\n _themeModule__WEBPACK_IMPORTED_MODULE_5__[\"default\"].loadThemes();\n _domtools__WEBPACK_IMPORTED_MODULE_8__[\"default\"].addStyle(\"customcss\", atob(_dataStore__WEBPACK_IMPORTED_MODULE_6__[\"default\"].getBDData(\"bdcustomcss\")));\n window.addEventListener(\"beforeunload\", function () {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-dc-0\"]) document.querySelector(\".btn.btn-disconnect\").click();\n });\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"Startup\", \"Removing Loading Icon\");\n if (document.getElementsByClassName(\"bd-loaderv2\").length) document.getElementsByClassName(\"bd-loaderv2\")[0].remove();\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"Startup\", \"Initializing Main Observer\");\n this.initObserver(); // Show loading errors\n\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-1\"]) {\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"Startup\", \"Collecting Startup Errors\");\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].showContentErrors({\n plugins: _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdpluginErrors\"],\n themes: _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemeErrors\"]\n });\n }\n\n const previousVersion = _dataStore__WEBPACK_IMPORTED_MODULE_6__[\"default\"].getBDData(\"version\");\n\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bbdVersion\"] > previousVersion) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bbdChangelog\"]) this.showChangelogModal(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bbdChangelog\"]);\n _dataStore__WEBPACK_IMPORTED_MODULE_6__[\"default\"].setBDData(\"version\", _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bbdVersion\"]);\n }\n\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].suppressErrors(this.patchSocial.bind(this), \"BD Social Patch\")();\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].suppressErrors(this.patchGuildPills.bind(this), \"BD Guild Pills Patch\")();\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].suppressErrors(this.patchGuildListItems.bind(this), \"BD Guild List Items Patch\")();\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].suppressErrors(this.patchGuildSeparator.bind(this), \"BD Guild Separator Patch\")();\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].suppressErrors(this.patchMessageHeader.bind(this), \"BD Badge Chat Patch\")();\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].suppressErrors(this.patchMemberList.bind(this), \"BD Badge Member List Patch\")();\n};\n\nCore.prototype.checkForGuilds = function () {\n let timesChecked = 0;\n return new Promise(resolve => {\n const checkForGuilds = function () {\n const wrapper = _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].guildClasses.wrapper.split(\" \")[0];\n if (document.querySelectorAll(`.${wrapper}`).length > 0) timesChecked++;\n const guild = _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].guildClasses.listItem.split(\" \")[0];\n const blob = _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].guildClasses.blobContainer.split(\" \")[0];\n if (document.querySelectorAll(`.${wrapper} .${guild} .${blob}`).length > 0) return resolve(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].deferLoaded = true);else if (timesChecked >= 50) return resolve(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].deferLoaded = true);\n setTimeout(checkForGuilds, 100);\n };\n\n if (document.readyState != \"loading\") setTimeout(checkForGuilds, 100);\n document.addEventListener(\"DOMContentLoaded\", () => {\n setTimeout(checkForGuilds, 100);\n });\n });\n};\n\nCore.prototype.injectExternals = async function () {\n await _domtools__WEBPACK_IMPORTED_MODULE_8__[\"default\"].addScript(\"ace-script\", \"https://cdnjs.cloudflare.com/ajax/libs/ace/1.2.9/ace.js\");\n if (window.require.original) window.require = window.require.original;\n};\n\nCore.prototype.initSettings = function () {\n _dataStore__WEBPACK_IMPORTED_MODULE_6__[\"default\"].initialize();\n\n if (!_dataStore__WEBPACK_IMPORTED_MODULE_6__[\"default\"].getSettingGroup(\"settings\")) {\n Object.assign(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"], _0globals__WEBPACK_IMPORTED_MODULE_0__[\"defaultCookie\"]);\n _settingsPanel__WEBPACK_IMPORTED_MODULE_3__[\"default\"].saveSettings();\n } else {\n _settingsPanel__WEBPACK_IMPORTED_MODULE_3__[\"default\"].loadSettings();\n\n for (const setting in _0globals__WEBPACK_IMPORTED_MODULE_0__[\"defaultCookie\"]) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][setting] == undefined) {\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][setting] = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"defaultCookie\"][setting];\n _settingsPanel__WEBPACK_IMPORTED_MODULE_3__[\"default\"].saveSettings();\n }\n }\n }\n};\n\nCore.prototype.initObserver = function () {\n const mainObserver = new MutationObserver(mutations => {\n for (let i = 0, mlen = mutations.length; i < mlen; i++) {\n const mutation = mutations[i];\n if (typeof _pluginModule__WEBPACK_IMPORTED_MODULE_4__[\"default\"] !== \"undefined\") _pluginModule__WEBPACK_IMPORTED_MODULE_4__[\"default\"].rawObserver(mutation); // if there was nothing added, skip\n\n if (!mutation.addedNodes.length || !(mutation.addedNodes[0] instanceof Element)) continue;\n const node = mutation.addedNodes[0];\n let [classNameLayer, classNameSocialLinks] = [BDModules.get(e => e.layer && typeof e.layer === \"string\" && e.animating)[0].layer, BDModules.get(e => e.socialLinks && typeof e.socialLinks === \"string\")[0].socialLinks];\n\n if (node.classList.contains(classNameLayer)) {\n if (node.getElementsByClassName(\"guild-settings-base-section\").length) node.setAttribute(\"layer-id\", \"server-settings\");\n\n if (node.getElementsByClassName(classNameSocialLinks).length) {\n node.setAttribute(\"layer-id\", \"user-settings\");\n node.setAttribute(\"id\", \"user-settings\");\n if (!document.getElementById(\"bd-settings-sidebar\")) _settingsPanel__WEBPACK_IMPORTED_MODULE_3__[\"default\"].renderSidebar();\n }\n }\n\n if (node.parentElement == document.body && node.querySelector(\"#ace_settingsmenu\")) node.id = \"ace_settingsmenu_container\"; // Emoji Picker\n //node.getElementsByClassName(\"emojiPicker-3m1S-j\").length && !node.querySelector(\".emojiPicker-3m1S-j\").parentElement.classList.contains(\"animatorLeft-1EQxU0\")\n //if (node.classList.contains(classNameLayer2) && node.getElementsByClassName(classNameEmojiPicker).length && !node.querySelector(\".\"+classNameEmojiPicker).parentElement.classList.contains(classNameAnimatorLeft)) quickEmoteMenu.obsCallback(node);\n }\n });\n mainObserver.observe(document, {\n childList: true,\n subtree: true\n });\n};\n\nCore.prototype.showChangelogModal = function (options = {}) {\n return _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].showChangelogModal(options);\n};\n\nCore.prototype.alert = function (title, content) {\n return _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].alert(title, content);\n};\n\nCore.prototype.patchSocial = function () {\n if (this.socialPatch) return;\n const TabBar = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].find(m => m.displayName == \"TabBar\");\n const Anchor = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].find(m => m.displayName == \"Anchor\");\n if (!TabBar) return;\n this.socialPatch = _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].monkeyPatch(TabBar.prototype, \"render\", {\n after: data => {\n const children = data.returnValue.props.children;\n if (!children || !children.length || children.length < 3) return;\n if (children[children.length - 3].type.displayName !== \"Separator\") return;\n if (!children[children.length - 2].type.toString().includes(\"socialLinks\")) return;\n\n if (Anchor) {\n const original = children[children.length - 2].type;\n\n const newOne = function () {\n const returnVal = original(...arguments);\n returnVal.props.children.push(_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(_ui_tooltipWrap__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n color: \"black\",\n side: \"top\",\n text: \"BandagedBD\"\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(Anchor, {\n className: \"bd-social-link\",\n href: \"https://github.com/rauenzi/BetterDiscordApp\",\n title: \"BandagedBD\",\n target: \"_blank\"\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(_ui_bdLogo__WEBPACK_IMPORTED_MODULE_9__[\"default\"], {\n size: \"16px\",\n className: \"bd-social-logo\"\n }))));\n return returnVal;\n };\n\n children[children.length - 2].type = newOne;\n }\n\n let [classNameColorMuted, sizes, classNameVersionHash] = [BDModules.get(e => e.colorMuted)[0].colorMuted, BDModules.get(e => e.size32)[0], BDModules.get(e => e.versionHash)[0].versionHash];\n const injector = _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n className: `${classNameColorMuted} ${sizes.size12}`\n }, `Injector ${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].version}`);\n const versionHash = `(${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].hash ? _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].hash.substring(0, 7) : _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].branch})`;\n const additional = _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n className: `${classNameColorMuted} ${sizes.size12}`\n }, `BBD ${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bbdVersion\"]} `, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"span\", {\n className: classNameVersionHash + \" da-versionHash\"\n }, versionHash));\n const originalVersions = children[children.length - 1].type;\n\n children[children.length - 1].type = function () {\n const returnVal = originalVersions(...arguments);\n returnVal.props.children.splice(returnVal.props.children.length - 1, 0, injector);\n returnVal.props.children.splice(1, 0, additional);\n return returnVal;\n };\n }\n });\n};\n\nconst getGuildClasses = function () {\n const guildsWrapper = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].findByProps(\"wrapper\", \"unreadMentionsBar\");\n const guilds = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].findByProps(\"guildsError\", \"selected\");\n const pill = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].findByProps(\"blobContainer\");\n return Object.assign({}, guildsWrapper, guilds, pill);\n};\n\nCore.prototype.patchGuildListItems = function () {\n if (this.guildListItemsPatch) return;\n const GuildClasses = getGuildClasses();\n const listItemClass = GuildClasses.listItem.split(\" \")[0];\n const blobClass = GuildClasses.blobContainer.split(\" \")[0];\n const reactInstance = _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].getInternalInstance(document.querySelector(`.${listItemClass} .${blobClass}`).parentElement);\n const GuildComponent = reactInstance.return.type;\n if (!GuildComponent) return;\n this.guildListItemsPatch = _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].monkeyPatch(GuildComponent.prototype, \"render\", {\n after: data => {\n if (data.returnValue && data.thisObject) {\n const returnValue = data.returnValue;\n const guildData = data.thisObject.props;\n returnValue.props.className += \" bd-guild\";\n if (guildData.unread) returnValue.props.className += \" bd-unread\";\n if (guildData.selected) returnValue.props.className += \" bd-selected\";\n if (guildData.audio) returnValue.props.className += \" bd-audio\";\n if (guildData.video) returnValue.props.className += \" bd-video\";\n if (guildData.badge) returnValue.props.className += \" bd-badge\";\n if (guildData.animatable) returnValue.props.className += \" bd-animatable\";\n return returnValue;\n }\n }\n });\n};\n\nCore.prototype.patchGuildPills = function () {\n if (this.guildPillPatch) return;\n const guildPill = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].find(m => m.default && !m.default.displayName && m.default.toString && m.default.toString().includes(\"translate3d\"));\n if (!guildPill) return;\n this.guildPillPatch = _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].monkeyPatch(guildPill, \"default\", {\n after: data => {\n const props = data.methodArguments[0];\n if (props.unread) data.returnValue.props.className += \" bd-unread\";\n if (props.selected) data.returnValue.props.className += \" bd-selected\";\n if (props.hovered) data.returnValue.props.className += \" bd-hovered\";\n return data.returnValue;\n }\n });\n};\n\nCore.prototype.patchGuildSeparator = function () {\n if (this.guildSeparatorPatch) return;\n const Guilds = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].findByDisplayName(\"Guilds\");\n const guildComponents = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].findByProps(\"renderListItem\");\n if (!guildComponents || !Guilds) return;\n\n const GuildSeparator = function () {\n const returnValue = guildComponents.Separator(...arguments);\n returnValue.props.className += \" bd-guild-separator\";\n return returnValue;\n };\n\n this.guildSeparatorPatch = _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].monkeyPatch(Guilds.prototype, \"render\", {\n after: data => {\n data.returnValue.props.children[1].props.children[3].type = GuildSeparator;\n }\n });\n};\n\nCore.prototype.patchMessageHeader = function () {\n if (this.messageHeaderPatch) return;\n const MessageHeader = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].findByProps(\"MessageTimestamp\");\n const Anchor = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].find(m => m.displayName == \"Anchor\");\n if (!Anchor || !MessageHeader || !MessageHeader.default) return;\n this.messageHeaderPatch = _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].monkeyPatch(MessageHeader, \"default\", {\n after: data => {\n const author = _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getNestedProp(data.methodArguments[0], \"message.author\"); // const header = Utils.getNestedProp(data.returnValue, \"props.children.1.props\");\n\n const children = _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getNestedProp(data.returnValue, \"props.children.1.props.children.1.props.children\");\n if (!children || !author || !author.id) return; // if (header && header.className) header.className += \" \"\n\n if (!Array.isArray(children)) return;\n\n if (author.id === \"249746236008169473\") {\n children.push(_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(_ui_tooltipWrap__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n color: \"black\",\n side: \"top\",\n text: \"BandagedBD Developer\"\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(Anchor, {\n className: \"bd-chat-badge\",\n href: \"https://github.com/rauenzi/BetterDiscordApp\",\n title: \"BandagedBD\",\n target: \"_blank\"\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(_ui_bdLogo__WEBPACK_IMPORTED_MODULE_9__[\"default\"], {\n size: \"16px\",\n className: \"bd-logo\"\n }))));\n } else if (author.id === \"696481194443014174\") {\n children.push(_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(_ui_tooltipWrap__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n color: \"black\",\n side: \"top\",\n text: \"Lightcord Developer\"\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(Anchor, {\n className: \"bd-chat-badge\",\n href: \"https://github.com/jeanouina/Lightcord\",\n title: \"Lightcord\",\n target: \"_blank\"\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(_ui_lightcordLogo__WEBPACK_IMPORTED_MODULE_11__[\"default\"], {\n size: \"32px\",\n className: \"bd-logo\"\n }))));\n }\n }\n });\n};\n\nCore.prototype.patchMemberList = function () {\n if (this.memberListPatch) return;\n const MemberListItem = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].findByDisplayName(\"MemberListItem\");\n const Anchor = _webpackModules__WEBPACK_IMPORTED_MODULE_7__[\"default\"].find(m => m.displayName == \"Anchor\");\n if (!Anchor || !MemberListItem || !MemberListItem.prototype || !MemberListItem.prototype.renderDecorators) return;\n this.memberListPatch = _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].monkeyPatch(MemberListItem.prototype, \"renderDecorators\", {\n after: data => {\n const user = _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getNestedProp(data.thisObject, \"props.user\");\n const children = _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getNestedProp(data.returnValue, \"props.children\");\n if (!children || !user || !user.id) return; // if (header && header.className) header.className += \" \"\n\n if (!Array.isArray(children)) return;\n\n if (user.id === \"249746236008169473\") {\n children.push(_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(_ui_tooltipWrap__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n color: \"black\",\n side: \"top\",\n text: \"BandagedBD Developer\"\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(Anchor, {\n className: \"bd-member-badge\",\n href: \"https://github.com/rauenzi/BetterDiscordApp\",\n title: \"BandagedBD\",\n target: \"_blank\"\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(_ui_bdLogo__WEBPACK_IMPORTED_MODULE_9__[\"default\"], {\n size: \"16px\",\n className: \"bd-logo\"\n }))));\n } else if (user.id === \"696481194443014174\") {\n children.push(_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(_ui_tooltipWrap__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n color: \"black\",\n side: \"top\",\n text: \"Lightcord Developer\"\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(Anchor, {\n className: \"bd-member-badge\",\n href: \"https://github.com/jeanouina/Lightcord\",\n title: \"Lightcord\",\n target: \"_blank\"\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(_ui_lightcordLogo__WEBPACK_IMPORTED_MODULE_11__[\"default\"], {\n size: \"32px\",\n className: \"bd-logo\"\n }))));\n }\n }\n });\n};\n\nCore.prototype.updateInjector = async function () {\n const injectionPath = _dataStore__WEBPACK_IMPORTED_MODULE_6__[\"default\"].injectionPath;\n if (!injectionPath) return false;\n\n const fs = __webpack_require__(/*! fs */ \"fs\");\n\n const path = __webpack_require__(/*! path */ \"path\");\n\n const rmrf = __webpack_require__(/*! rimraf */ \"rimraf\");\n\n const yauzl = __webpack_require__(/*! yauzl */ \"yauzl\");\n\n const mkdirp = __webpack_require__(/*! mkdirp */ \"mkdirp\");\n\n const request =\n /*require(\"request\");*/\n null;\n const parentPath = path.resolve(injectionPath, \"..\");\n const folderName = path.basename(injectionPath);\n const zipLink = \"https://github.com/rauenzi/BetterDiscordApp/archive/injector.zip\";\n const savedZip = path.resolve(parentPath, \"injector.zip\");\n const extractedFolder = path.resolve(parentPath, \"BetterDiscordApp-injector\"); // Download the injector zip file\n\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"InjectorUpdate\", \"Downloading \" + zipLink);\n let success = await new Promise(resolve => {\n request.get({\n url: zipLink,\n encoding: null\n }, async (error, response, body) => {\n if (error || response.statusCode !== 200) return resolve(false); // Save a backup in case someone has their own copy\n\n const alreadyExists = await new Promise(res => fs.exists(savedZip, res));\n if (alreadyExists) await new Promise(res => fs.rename(savedZip, `${savedZip}.bak${Math.round(performance.now())}`, res));\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"InjectorUpdate\", \"Writing \" + savedZip);\n fs.writeFile(savedZip, body, err => resolve(!err));\n });\n });\n if (!success) return success; // Check and delete rename extraction\n\n const alreadyExists = await new Promise(res => fs.exists(extractedFolder, res));\n if (alreadyExists) await new Promise(res => fs.rename(extractedFolder, `${extractedFolder}.bak${Math.round(performance.now())}`, res)); // Unzip the downloaded zip file\n\n const zipfile = await new Promise(r => yauzl.open(savedZip, {\n lazyEntries: true\n }, (err, zip) => r(zip)));\n zipfile.on(\"entry\", function (entry) {\n // Skip directories, they are handled with mkdirp\n if (entry.fileName.endsWith(\"/\")) return zipfile.readEntry();\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"InjectorUpdate\", \"Extracting \" + entry.fileName); // Make any needed parent directories\n\n const fullPath = path.resolve(parentPath, entry.fileName);\n mkdirp.sync(path.dirname(fullPath));\n zipfile.openReadStream(entry, function (err, readStream) {\n if (err) return success = false;\n readStream.on(\"end\", function () {\n zipfile.readEntry();\n }); // Go to next file after this\n\n readStream.pipe(fs.createWriteStream(fullPath));\n });\n });\n zipfile.readEntry(); // Start reading\n // Wait for the final file to finish\n\n await new Promise(resolve => zipfile.once(\"end\", resolve)); // Save a backup in case something goes wrong during final step\n\n const backupFolder = path.resolve(parentPath, `${folderName}.bak${Math.round(performance.now())}`);\n await new Promise(resolve => fs.rename(injectionPath, backupFolder, resolve)); // Rename the extracted folder to what it should be\n\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"InjectorUpdate\", `Renaming ${path.basename(extractedFolder)} to ${folderName}`);\n success = await new Promise(resolve => fs.rename(extractedFolder, injectionPath, err => resolve(!err)));\n\n if (!success) {\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].err(\"InjectorUpdate\", \"Failed to rename the final directory\");\n return success;\n } // If rename had issues, delete what we tried to rename and restore backup\n\n\n if (!success) {\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].err(\"InjectorUpdate\", \"Something went wrong... restoring backups.\");\n await new Promise(resolve => rmrf(extractedFolder, resolve));\n await new Promise(resolve => fs.rename(backupFolder, injectionPath, resolve));\n return success;\n } // If we've gotten to this point, everything should have gone smoothly.\n // Cleanup the backup folder then remove the zip\n\n\n await new Promise(resolve => rmrf(backupFolder, resolve));\n await new Promise(resolve => fs.unlink(savedZip, resolve));\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].log(\"InjectorUpdate\", \"Injector Updated!\");\n return success;\n};\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (new Core());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/modules/core.js.js","sources":["webpack://BetterDiscord/./src/modules/core.js?13c2"],"sourcesContent":["import { bdConfig, minSupportedVersion, bbdVersion, settingsCookie, bdpluginErrors, bdthemeErrors, bbdChangelog, defaultCookie, currentDiscordVersion } from \"../0globals\";\nimport Utils from \"./utils\";\nimport BDV2 from \"./v2\";\nimport settingsPanel from \"./settingsPanel\";\nimport pluginModule from \"./pluginModule\";\nimport themeModule from \"./themeModule\";\nimport DataStore from \"./dataStore\";\nimport WebpackModules from \"./webpackModules\";\nimport DOM from \"./domtools\";\nimport BDLogo from \"../ui/bdLogo\";\nimport TooltipWrap from \"../ui/tooltipWrap\";\nimport LightcordLogo from \"../ui/lightcordLogo\";\n\nfunction Core() {// Object.assign(bdConfig, __non_webpack_require__(DataStore.configFile));\n  // this.init();\n}\n\nCore.prototype.setConfig = function (config) {\n  Object.assign(bdConfig, config);\n};\n\nCore.prototype.init = async function () {\n  if (!Array.prototype.flat) {\n    Utils.alert(\"Not Supported\", \"BetterDiscord v\" + bbdVersion + \" does not support this old version (\" + currentDiscordVersion + \") of Discord. Please update your Discord installation before proceeding.\");\n    return;\n  }\n\n  if (bdConfig.version < minSupportedVersion) {\n    Utils.alert(\"Not Supported\", \"BetterDiscord v\" + bdConfig.version + \" (your version)\" + \" is not supported by the latest js (\" + bbdVersion + \").<br><br> Please download the latest version from <a href='https://github.com/rauenzi/BetterDiscordApp/releases/latest' target='_blank'>GitHub</a>\");\n    return;\n  }\n\n  if (window.ED) {\n    Utils.alert(\"Not Supported\", \"BandagedBD does not work with EnhancedDiscord. Please uninstall one of them.\");\n    return;\n  }\n\n  if (window.WebSocket && window.WebSocket.name && window.WebSocket.name.includes(\"Patched\")) {\n    Utils.alert(\"Not Supported\", \"BandagedBD does not work with Powercord. Please uninstall one of them.\");\n    return;\n  }\n\n  const latestLocalVersion = bdConfig.updater ? bdConfig.updater.LatestVersion : bdConfig.latestVersion;\n\n  if (latestLocalVersion > bdConfig.version) {\n    Utils.showConfirmationModal(\"Update Available\", [`There is an update available for BandagedBD's Injector (${latestLocalVersion}).`, \"You can either update and restart now, or later.\"], {\n      confirmText: \"Update Now\",\n      cancelText: \"Maybe Later\",\n      onConfirm: async () => {\n        const onUpdateFailed = () => {\n          Utils.alert(\"Could Not Update\", `Unable to update automatically, please download the installer and reinstall normally.<br /><br /><a href='https://github.com/rauenzi/BetterDiscordApp/releases/latest' target='_blank'>Download Installer</a>`);\n        };\n\n        try {\n          const didUpdate = await this.updateInjector();\n          if (!didUpdate) return onUpdateFailed();\n\n          const app = require(\"electron\").remote.app;\n\n          app.relaunch();\n          app.exit();\n        } catch (err) {\n          onUpdateFailed();\n        }\n      }\n    });\n  }\n\n  Utils.log(\"Startup\", \"Initializing Settings\");\n  this.initSettings();\n  await this.checkForGuilds();\n  BDV2.initialize();\n  Utils.log(\"Startup\", \"Updating Settings\");\n  settingsPanel.initializeSettings();\n  Utils.log(\"Startup\", \"Loading Plugins\");\n  pluginModule.loadPlugins();\n  Utils.log(\"Startup\", \"Loading Themes\");\n  themeModule.loadThemes();\n  DOM.addStyle(\"customcss\", atob(DataStore.getBDData(\"bdcustomcss\")));\n  window.addEventListener(\"beforeunload\", function () {\n    if (settingsCookie[\"bda-dc-0\"]) document.querySelector(\".btn.btn-disconnect\").click();\n  });\n  Utils.log(\"Startup\", \"Removing Loading Icon\");\n  if (document.getElementsByClassName(\"bd-loaderv2\").length) document.getElementsByClassName(\"bd-loaderv2\")[0].remove();\n  Utils.log(\"Startup\", \"Initializing Main Observer\");\n  this.initObserver(); // Show loading errors\n\n  if (settingsCookie[\"fork-ps-1\"]) {\n    Utils.log(\"Startup\", \"Collecting Startup Errors\");\n    Utils.showContentErrors({\n      plugins: bdpluginErrors,\n      themes: bdthemeErrors\n    });\n  }\n\n  const previousVersion = DataStore.getBDData(\"version\");\n\n  if (bbdVersion > previousVersion) {\n    if (bbdChangelog) this.showChangelogModal(bbdChangelog);\n    DataStore.setBDData(\"version\", bbdVersion);\n  }\n\n  Utils.suppressErrors(this.patchSocial.bind(this), \"BD Social Patch\")();\n  Utils.suppressErrors(this.patchGuildPills.bind(this), \"BD Guild Pills Patch\")();\n  Utils.suppressErrors(this.patchGuildListItems.bind(this), \"BD Guild List Items Patch\")();\n  Utils.suppressErrors(this.patchGuildSeparator.bind(this), \"BD Guild Separator Patch\")();\n  Utils.suppressErrors(this.patchMessageHeader.bind(this), \"BD Badge Chat Patch\")();\n  Utils.suppressErrors(this.patchMemberList.bind(this), \"BD Badge Member List Patch\")();\n};\n\nCore.prototype.checkForGuilds = function () {\n  let timesChecked = 0;\n  return new Promise(resolve => {\n    const checkForGuilds = function () {\n      const wrapper = BDV2.guildClasses.wrapper.split(\" \")[0];\n      if (document.querySelectorAll(`.${wrapper}`).length > 0) timesChecked++;\n      const guild = BDV2.guildClasses.listItem.split(\" \")[0];\n      const blob = BDV2.guildClasses.blobContainer.split(\" \")[0];\n      if (document.querySelectorAll(`.${wrapper} .${guild} .${blob}`).length > 0) return resolve(bdConfig.deferLoaded = true);else if (timesChecked >= 50) return resolve(bdConfig.deferLoaded = true);\n      setTimeout(checkForGuilds, 100);\n    };\n\n    if (document.readyState != \"loading\") setTimeout(checkForGuilds, 100);\n    document.addEventListener(\"DOMContentLoaded\", () => {\n      setTimeout(checkForGuilds, 100);\n    });\n  });\n};\n\nCore.prototype.injectExternals = async function () {\n  await DOM.addScript(\"ace-script\", \"https://cdnjs.cloudflare.com/ajax/libs/ace/1.2.9/ace.js\");\n  if (window.require.original) window.require = window.require.original;\n};\n\nCore.prototype.initSettings = function () {\n  DataStore.initialize();\n\n  if (!DataStore.getSettingGroup(\"settings\")) {\n    Object.assign(settingsCookie, defaultCookie);\n    settingsPanel.saveSettings();\n  } else {\n    settingsPanel.loadSettings();\n\n    for (const setting in defaultCookie) {\n      if (settingsCookie[setting] == undefined) {\n        settingsCookie[setting] = defaultCookie[setting];\n        settingsPanel.saveSettings();\n      }\n    }\n  }\n};\n\nCore.prototype.initObserver = function () {\n  const mainObserver = new MutationObserver(mutations => {\n    for (let i = 0, mlen = mutations.length; i < mlen; i++) {\n      const mutation = mutations[i];\n      if (typeof pluginModule !== \"undefined\") pluginModule.rawObserver(mutation); // if there was nothing added, skip\n\n      if (!mutation.addedNodes.length || !(mutation.addedNodes[0] instanceof Element)) continue;\n      const node = mutation.addedNodes[0];\n      let [classNameLayer, classNameSocialLinks] = [BDModules.get(e => e.layer && typeof e.layer === \"string\" && e.animating)[0].layer, BDModules.get(e => e.socialLinks && typeof e.socialLinks === \"string\")[0].socialLinks];\n\n      if (node.classList.contains(classNameLayer)) {\n        if (node.getElementsByClassName(\"guild-settings-base-section\").length) node.setAttribute(\"layer-id\", \"server-settings\");\n\n        if (node.getElementsByClassName(classNameSocialLinks).length) {\n          node.setAttribute(\"layer-id\", \"user-settings\");\n          node.setAttribute(\"id\", \"user-settings\");\n          if (!document.getElementById(\"bd-settings-sidebar\")) settingsPanel.renderSidebar();\n        }\n      }\n\n      if (node.parentElement == document.body && node.querySelector(\"#ace_settingsmenu\")) node.id = \"ace_settingsmenu_container\"; // Emoji Picker\n      //node.getElementsByClassName(\"emojiPicker-3m1S-j\").length && !node.querySelector(\".emojiPicker-3m1S-j\").parentElement.classList.contains(\"animatorLeft-1EQxU0\")\n      //if (node.classList.contains(classNameLayer2) && node.getElementsByClassName(classNameEmojiPicker).length  && !node.querySelector(\".\"+classNameEmojiPicker).parentElement.classList.contains(classNameAnimatorLeft)) quickEmoteMenu.obsCallback(node);\n    }\n  });\n  mainObserver.observe(document, {\n    childList: true,\n    subtree: true\n  });\n};\n\nCore.prototype.showChangelogModal = function (options = {}) {\n  return Utils.showChangelogModal(options);\n};\n\nCore.prototype.alert = function (title, content) {\n  return Utils.alert(title, content);\n};\n\nCore.prototype.patchSocial = function () {\n  if (this.socialPatch) return;\n  const TabBar = WebpackModules.find(m => m.displayName == \"TabBar\");\n  const Anchor = WebpackModules.find(m => m.displayName == \"Anchor\");\n  if (!TabBar) return;\n  this.socialPatch = Utils.monkeyPatch(TabBar.prototype, \"render\", {\n    after: data => {\n      const children = data.returnValue.props.children;\n      if (!children || !children.length || children.length < 3) return;\n      if (children[children.length - 3].type.displayName !== \"Separator\") return;\n      if (!children[children.length - 2].type.toString().includes(\"socialLinks\")) return;\n\n      if (Anchor) {\n        const original = children[children.length - 2].type;\n\n        const newOne = function () {\n          const returnVal = original(...arguments);\n          returnVal.props.children.push(BDV2.React.createElement(TooltipWrap, {\n            color: \"black\",\n            side: \"top\",\n            text: \"BandagedBD\"\n          }, BDV2.React.createElement(Anchor, {\n            className: \"bd-social-link\",\n            href: \"https://github.com/rauenzi/BetterDiscordApp\",\n            title: \"BandagedBD\",\n            target: \"_blank\"\n          }, BDV2.React.createElement(BDLogo, {\n            size: \"16px\",\n            className: \"bd-social-logo\"\n          }))));\n          return returnVal;\n        };\n\n        children[children.length - 2].type = newOne;\n      }\n\n      let [classNameColorMuted, sizes, classNameVersionHash] = [BDModules.get(e => e.colorMuted)[0].colorMuted, BDModules.get(e => e.size32)[0], BDModules.get(e => e.versionHash)[0].versionHash];\n      const injector = BDV2.react.createElement(\"div\", {\n        className: `${classNameColorMuted} ${sizes.size12}`\n      }, `Injector ${bdConfig.version}`);\n      const versionHash = `(${bdConfig.hash ? bdConfig.hash.substring(0, 7) : bdConfig.branch})`;\n      const additional = BDV2.react.createElement(\"div\", {\n        className: `${classNameColorMuted} ${sizes.size12}`\n      }, `BBD ${bbdVersion} `, BDV2.react.createElement(\"span\", {\n        className: classNameVersionHash + \" da-versionHash\"\n      }, versionHash));\n      const originalVersions = children[children.length - 1].type;\n\n      children[children.length - 1].type = function () {\n        const returnVal = originalVersions(...arguments);\n        returnVal.props.children.splice(returnVal.props.children.length - 1, 0, injector);\n        returnVal.props.children.splice(1, 0, additional);\n        return returnVal;\n      };\n    }\n  });\n};\n\nconst getGuildClasses = function () {\n  const guildsWrapper = WebpackModules.findByProps(\"wrapper\", \"unreadMentionsBar\");\n  const guilds = WebpackModules.findByProps(\"guildsError\", \"selected\");\n  const pill = WebpackModules.findByProps(\"blobContainer\");\n  return Object.assign({}, guildsWrapper, guilds, pill);\n};\n\nCore.prototype.patchGuildListItems = function () {\n  if (this.guildListItemsPatch) return;\n  const GuildClasses = getGuildClasses();\n  const listItemClass = GuildClasses.listItem.split(\" \")[0];\n  const blobClass = GuildClasses.blobContainer.split(\" \")[0];\n  const reactInstance = BDV2.getInternalInstance(document.querySelector(`.${listItemClass} .${blobClass}`).parentElement);\n  const GuildComponent = reactInstance.return.type;\n  if (!GuildComponent) return;\n  this.guildListItemsPatch = Utils.monkeyPatch(GuildComponent.prototype, \"render\", {\n    after: data => {\n      if (data.returnValue && data.thisObject) {\n        const returnValue = data.returnValue;\n        const guildData = data.thisObject.props;\n        returnValue.props.className += \" bd-guild\";\n        if (guildData.unread) returnValue.props.className += \" bd-unread\";\n        if (guildData.selected) returnValue.props.className += \" bd-selected\";\n        if (guildData.audio) returnValue.props.className += \" bd-audio\";\n        if (guildData.video) returnValue.props.className += \" bd-video\";\n        if (guildData.badge) returnValue.props.className += \" bd-badge\";\n        if (guildData.animatable) returnValue.props.className += \" bd-animatable\";\n        return returnValue;\n      }\n    }\n  });\n};\n\nCore.prototype.patchGuildPills = function () {\n  if (this.guildPillPatch) return;\n  const guildPill = WebpackModules.find(m => m.default && !m.default.displayName && m.default.toString && m.default.toString().includes(\"translate3d\"));\n  if (!guildPill) return;\n  this.guildPillPatch = Utils.monkeyPatch(guildPill, \"default\", {\n    after: data => {\n      const props = data.methodArguments[0];\n      if (props.unread) data.returnValue.props.className += \" bd-unread\";\n      if (props.selected) data.returnValue.props.className += \" bd-selected\";\n      if (props.hovered) data.returnValue.props.className += \" bd-hovered\";\n      return data.returnValue;\n    }\n  });\n};\n\nCore.prototype.patchGuildSeparator = function () {\n  if (this.guildSeparatorPatch) return;\n  const Guilds = WebpackModules.findByDisplayName(\"Guilds\");\n  const guildComponents = WebpackModules.findByProps(\"renderListItem\");\n  if (!guildComponents || !Guilds) return;\n\n  const GuildSeparator = function () {\n    const returnValue = guildComponents.Separator(...arguments);\n    returnValue.props.className += \" bd-guild-separator\";\n    return returnValue;\n  };\n\n  this.guildSeparatorPatch = Utils.monkeyPatch(Guilds.prototype, \"render\", {\n    after: data => {\n      data.returnValue.props.children[1].props.children[3].type = GuildSeparator;\n    }\n  });\n};\n\nCore.prototype.patchMessageHeader = function () {\n  if (this.messageHeaderPatch) return;\n  const MessageHeader = WebpackModules.findByProps(\"MessageTimestamp\");\n  const Anchor = WebpackModules.find(m => m.displayName == \"Anchor\");\n  if (!Anchor || !MessageHeader || !MessageHeader.default) return;\n  this.messageHeaderPatch = Utils.monkeyPatch(MessageHeader, \"default\", {\n    after: data => {\n      const author = Utils.getNestedProp(data.methodArguments[0], \"message.author\"); // const header = Utils.getNestedProp(data.returnValue, \"props.children.1.props\");\n\n      const children = Utils.getNestedProp(data.returnValue, \"props.children.1.props.children.1.props.children\");\n      if (!children || !author || !author.id) return; // if (header && header.className) header.className += \" \"\n\n      if (!Array.isArray(children)) return;\n\n      if (author.id === \"249746236008169473\") {\n        children.push(BDV2.React.createElement(TooltipWrap, {\n          color: \"black\",\n          side: \"top\",\n          text: \"BandagedBD Developer\"\n        }, BDV2.React.createElement(Anchor, {\n          className: \"bd-chat-badge\",\n          href: \"https://github.com/rauenzi/BetterDiscordApp\",\n          title: \"BandagedBD\",\n          target: \"_blank\"\n        }, BDV2.React.createElement(BDLogo, {\n          size: \"16px\",\n          className: \"bd-logo\"\n        }))));\n      } else if (author.id === \"696481194443014174\") {\n        children.push(BDV2.React.createElement(TooltipWrap, {\n          color: \"black\",\n          side: \"top\",\n          text: \"Lightcord Developer\"\n        }, BDV2.React.createElement(Anchor, {\n          className: \"bd-chat-badge\",\n          href: \"https://github.com/jeanouina/Lightcord\",\n          title: \"Lightcord\",\n          target: \"_blank\"\n        }, BDV2.React.createElement(LightcordLogo, {\n          size: \"32px\",\n          className: \"bd-logo\"\n        }))));\n      }\n    }\n  });\n};\n\nCore.prototype.patchMemberList = function () {\n  if (this.memberListPatch) return;\n  const MemberListItem = WebpackModules.findByDisplayName(\"MemberListItem\");\n  const Anchor = WebpackModules.find(m => m.displayName == \"Anchor\");\n  if (!Anchor || !MemberListItem || !MemberListItem.prototype || !MemberListItem.prototype.renderDecorators) return;\n  this.memberListPatch = Utils.monkeyPatch(MemberListItem.prototype, \"renderDecorators\", {\n    after: data => {\n      const user = Utils.getNestedProp(data.thisObject, \"props.user\");\n      const children = Utils.getNestedProp(data.returnValue, \"props.children\");\n      if (!children || !user || !user.id) return; // if (header && header.className) header.className += \" \"\n\n      if (!Array.isArray(children)) return;\n\n      if (user.id === \"249746236008169473\") {\n        children.push(BDV2.React.createElement(TooltipWrap, {\n          color: \"black\",\n          side: \"top\",\n          text: \"BandagedBD Developer\"\n        }, BDV2.React.createElement(Anchor, {\n          className: \"bd-member-badge\",\n          href: \"https://github.com/rauenzi/BetterDiscordApp\",\n          title: \"BandagedBD\",\n          target: \"_blank\"\n        }, BDV2.React.createElement(BDLogo, {\n          size: \"16px\",\n          className: \"bd-logo\"\n        }))));\n      } else if (user.id === \"696481194443014174\") {\n        children.push(BDV2.React.createElement(TooltipWrap, {\n          color: \"black\",\n          side: \"top\",\n          text: \"Lightcord Developer\"\n        }, BDV2.React.createElement(Anchor, {\n          className: \"bd-member-badge\",\n          href: \"https://github.com/jeanouina/Lightcord\",\n          title: \"Lightcord\",\n          target: \"_blank\"\n        }, BDV2.React.createElement(LightcordLogo, {\n          size: \"32px\",\n          className: \"bd-logo\"\n        }))));\n      }\n    }\n  });\n};\n\nCore.prototype.updateInjector = async function () {\n  const injectionPath = DataStore.injectionPath;\n  if (!injectionPath) return false;\n\n  const fs = require(\"fs\");\n\n  const path = require(\"path\");\n\n  const rmrf = require(\"rimraf\");\n\n  const yauzl = require(\"yauzl\");\n\n  const mkdirp = require(\"mkdirp\");\n\n  const request =\n  /*require(\"request\");*/\n  null;\n  const parentPath = path.resolve(injectionPath, \"..\");\n  const folderName = path.basename(injectionPath);\n  const zipLink = \"https://github.com/rauenzi/BetterDiscordApp/archive/injector.zip\";\n  const savedZip = path.resolve(parentPath, \"injector.zip\");\n  const extractedFolder = path.resolve(parentPath, \"BetterDiscordApp-injector\"); // Download the injector zip file\n\n  Utils.log(\"InjectorUpdate\", \"Downloading \" + zipLink);\n  let success = await new Promise(resolve => {\n    request.get({\n      url: zipLink,\n      encoding: null\n    }, async (error, response, body) => {\n      if (error || response.statusCode !== 200) return resolve(false); // Save a backup in case someone has their own copy\n\n      const alreadyExists = await new Promise(res => fs.exists(savedZip, res));\n      if (alreadyExists) await new Promise(res => fs.rename(savedZip, `${savedZip}.bak${Math.round(performance.now())}`, res));\n      Utils.log(\"InjectorUpdate\", \"Writing \" + savedZip);\n      fs.writeFile(savedZip, body, err => resolve(!err));\n    });\n  });\n  if (!success) return success; // Check and delete rename extraction\n\n  const alreadyExists = await new Promise(res => fs.exists(extractedFolder, res));\n  if (alreadyExists) await new Promise(res => fs.rename(extractedFolder, `${extractedFolder}.bak${Math.round(performance.now())}`, res)); // Unzip the downloaded zip file\n\n  const zipfile = await new Promise(r => yauzl.open(savedZip, {\n    lazyEntries: true\n  }, (err, zip) => r(zip)));\n  zipfile.on(\"entry\", function (entry) {\n    // Skip directories, they are handled with mkdirp\n    if (entry.fileName.endsWith(\"/\")) return zipfile.readEntry();\n    Utils.log(\"InjectorUpdate\", \"Extracting \" + entry.fileName); // Make any needed parent directories\n\n    const fullPath = path.resolve(parentPath, entry.fileName);\n    mkdirp.sync(path.dirname(fullPath));\n    zipfile.openReadStream(entry, function (err, readStream) {\n      if (err) return success = false;\n      readStream.on(\"end\", function () {\n        zipfile.readEntry();\n      }); // Go to next file after this\n\n      readStream.pipe(fs.createWriteStream(fullPath));\n    });\n  });\n  zipfile.readEntry(); // Start reading\n  // Wait for the final file to finish\n\n  await new Promise(resolve => zipfile.once(\"end\", resolve)); // Save a backup in case something goes wrong during final step\n\n  const backupFolder = path.resolve(parentPath, `${folderName}.bak${Math.round(performance.now())}`);\n  await new Promise(resolve => fs.rename(injectionPath, backupFolder, resolve)); // Rename the extracted folder to what it should be\n\n  Utils.log(\"InjectorUpdate\", `Renaming ${path.basename(extractedFolder)} to ${folderName}`);\n  success = await new Promise(resolve => fs.rename(extractedFolder, injectionPath, err => resolve(!err)));\n\n  if (!success) {\n    Utils.err(\"InjectorUpdate\", \"Failed to rename the final directory\");\n    return success;\n  } // If rename had issues, delete what we tried to rename and restore backup\n\n\n  if (!success) {\n    Utils.err(\"InjectorUpdate\", \"Something went wrong... restoring backups.\");\n    await new Promise(resolve => rmrf(extractedFolder, resolve));\n    await new Promise(resolve => fs.rename(backupFolder, injectionPath, resolve));\n    return success;\n  } // If we've gotten to this point, everything should have gone smoothly.\n  // Cleanup the backup folder then remove the zip\n\n\n  await new Promise(resolve => rmrf(backupFolder, resolve));\n  await new Promise(resolve => fs.unlink(savedZip, resolve));\n  Utils.log(\"InjectorUpdate\", \"Injector Updated!\");\n  return success;\n};\n\nexport default new Core();"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/modules/core.js\n"); + +/***/ }), + +/***/ "./src/modules/dataStore.js": +/*!**********************************!*\ + !*** ./src/modules/dataStore.js ***! + \**********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _contentManager__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./contentManager */ \"./src/modules/contentManager.js\");\nconst __non_webpack_require__ = window.require;\n\n\n\n\nconst fs = __webpack_require__(/*! fs */ \"fs\");\n\nconst path = __webpack_require__(/*! path */ \"path\");\n\nconst releaseChannel = DiscordNative.globals.releaseChannel;\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class DataStore {\n constructor() {\n this.data = {\n settings: {\n stable: {},\n canary: {},\n ptb: {}\n }\n };\n this.pluginData = {};\n }\n\n initialize() {\n try {\n if (!fs.existsSync(this.BDFile)) fs.writeFileSync(this.BDFile, JSON.stringify(this.data, null, 4), \"binary\");\n const data = JSON.parse(fs.readFileSync(this.BDFile, \"binary\"));\n if (data.hasOwnProperty(\"settings\")) this.data = data;\n if (!fs.existsSync(this.settingsFile)) return;\n\n let settings = __non_webpack_require__(this.settingsFile);\n\n fs.unlinkSync(this.settingsFile);\n if (settings.hasOwnProperty(\"settings\")) settings = Object.assign({\n stable: {},\n canary: {},\n ptb: {}\n }, {\n [releaseChannel]: settings\n });else settings = Object.assign({\n stable: {},\n canary: {},\n ptb: {}\n }, settings);\n this.setBDData(\"settings\", settings);\n } catch (err) {\n console.error(err);\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].alert(\"Corrupt Storage\", \"The bd storage has somehow become corrupt. You may either try to salvage the file or delete it then reload.\");\n }\n }\n\n get injectionPath() {\n if (this._injectionPath) return this._injectionPath;\n\n const electron = __webpack_require__(/*! electron */ \"electron\").remote.app;\n\n const base = electron.getAppPath();\n const roamingBase = electron.getPath(\"userData\");\n const roamingLocation = path.resolve(roamingBase, electron.getVersion(), \"modules\", \"discord_desktop_core\", \"injector\");\n const location = path.resolve(base, \"..\", \"app\");\n const realLocation = fs.existsSync(location) ? location : fs.existsSync(roamingLocation) ? roamingLocation : null;\n if (!realLocation) return this._injectionPath = null;\n return this._injectionPath = realLocation;\n }\n\n get configFile() {\n return this._configFile || (this._configFile = path.resolve(this.injectionPath, \"betterdiscord\", \"config.json\"));\n }\n\n get BDFile() {\n return this._BDFile || (this._BDFile = path.resolve(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].dataPath, \"bdstorage.json\"));\n }\n\n get settingsFile() {\n return this._settingsFile || (this._settingsFile = path.resolve(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdConfig\"].dataPath, \"bdsettings.json\"));\n }\n\n getPluginFile(pluginName) {\n return path.resolve(_contentManager__WEBPACK_IMPORTED_MODULE_2__[\"default\"].pluginsFolder, pluginName + \".config.json\");\n }\n\n getSettingGroup(key) {\n return this.data.settings[releaseChannel][key] || null;\n }\n\n setSettingGroup(key, data) {\n this.data.settings[releaseChannel][key] = data;\n fs.writeFileSync(this.BDFile, JSON.stringify(this.data, null, 4), \"binary\");\n }\n\n getBDData(key) {\n return this.data[key] || \"\";\n }\n\n setBDData(key, value) {\n this.data[key] = value;\n fs.writeFileSync(this.BDFile, JSON.stringify(this.data, null, 4), \"binary\");\n }\n\n getPluginData(pluginName, key) {\n if (this.pluginData[pluginName] !== undefined) return this.pluginData[pluginName][key] || undefined;\n if (!fs.existsSync(this.getPluginFile(pluginName))) return undefined;\n this.pluginData[pluginName] = JSON.parse(fs.readFileSync(this.getPluginFile(pluginName)));\n return this.pluginData[pluginName][key] || undefined;\n }\n\n setPluginData(pluginName, key, value) {\n if (value === undefined) return;\n if (this.pluginData[pluginName] === undefined) this.pluginData[pluginName] = {};\n this.pluginData[pluginName][key] = value;\n fs.writeFileSync(this.getPluginFile(pluginName), JSON.stringify(this.pluginData[pluginName], null, 4), \"binary\");\n }\n\n deletePluginData(pluginName, key) {\n if (this.pluginData[pluginName] === undefined) this.pluginData[pluginName] = {};\n delete this.pluginData[pluginName][key];\n fs.writeFileSync(this.getPluginFile(pluginName), JSON.stringify(this.pluginData[pluginName], null, 4), \"binary\");\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbW9kdWxlcy9kYXRhU3RvcmUuanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL21vZHVsZXMvZGF0YVN0b3JlLmpzPzg1ZGIiXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgX19ub25fd2VicGFja19yZXF1aXJlX18gPSB3aW5kb3cucmVxdWlyZTtcbmltcG9ydCB7IGJkQ29uZmlnIH0gZnJvbSBcIi4uLzBnbG9iYWxzXCI7XG5pbXBvcnQgVXRpbHMgZnJvbSBcIi4vdXRpbHNcIjtcbmltcG9ydCBDb250ZW50TWFuYWdlciBmcm9tIFwiLi9jb250ZW50TWFuYWdlclwiO1xuXG5jb25zdCBmcyA9IHJlcXVpcmUoXCJmc1wiKTtcblxuY29uc3QgcGF0aCA9IHJlcXVpcmUoXCJwYXRoXCIpO1xuXG5jb25zdCByZWxlYXNlQ2hhbm5lbCA9IERpc2NvcmROYXRpdmUuZ2xvYmFscy5yZWxlYXNlQ2hhbm5lbDtcbmV4cG9ydCBkZWZhdWx0IG5ldyBjbGFzcyBEYXRhU3RvcmUge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLmRhdGEgPSB7XG4gICAgICBzZXR0aW5nczoge1xuICAgICAgICBzdGFibGU6IHt9LFxuICAgICAgICBjYW5hcnk6IHt9LFxuICAgICAgICBwdGI6IHt9XG4gICAgICB9XG4gICAgfTtcbiAgICB0aGlzLnBsdWdpbkRhdGEgPSB7fTtcbiAgfVxuXG4gIGluaXRpYWxpemUoKSB7XG4gICAgdHJ5IHtcbiAgICAgIGlmICghZnMuZXhpc3RzU3luYyh0aGlzLkJERmlsZSkpIGZzLndyaXRlRmlsZVN5bmModGhpcy5CREZpbGUsIEpTT04uc3RyaW5naWZ5KHRoaXMuZGF0YSwgbnVsbCwgNCksIFwiYmluYXJ5XCIpO1xuICAgICAgY29uc3QgZGF0YSA9IEpTT04ucGFyc2UoZnMucmVhZEZpbGVTeW5jKHRoaXMuQkRGaWxlLCBcImJpbmFyeVwiKSk7XG4gICAgICBpZiAoZGF0YS5oYXNPd25Qcm9wZXJ0eShcInNldHRpbmdzXCIpKSB0aGlzLmRhdGEgPSBkYXRhO1xuICAgICAgaWYgKCFmcy5leGlzdHNTeW5jKHRoaXMuc2V0dGluZ3NGaWxlKSkgcmV0dXJuO1xuXG4gICAgICBsZXQgc2V0dGluZ3MgPSBfX25vbl93ZWJwYWNrX3JlcXVpcmVfXyh0aGlzLnNldHRpbmdzRmlsZSk7XG5cbiAgICAgIGZzLnVubGlua1N5bmModGhpcy5zZXR0aW5nc0ZpbGUpO1xuICAgICAgaWYgKHNldHRpbmdzLmhhc093blByb3BlcnR5KFwic2V0dGluZ3NcIikpIHNldHRpbmdzID0gT2JqZWN0LmFzc2lnbih7XG4gICAgICAgIHN0YWJsZToge30sXG4gICAgICAgIGNhbmFyeToge30sXG4gICAgICAgIHB0Yjoge31cbiAgICAgIH0sIHtcbiAgICAgICAgW3JlbGVhc2VDaGFubmVsXTogc2V0dGluZ3NcbiAgICAgIH0pO2Vsc2Ugc2V0dGluZ3MgPSBPYmplY3QuYXNzaWduKHtcbiAgICAgICAgc3RhYmxlOiB7fSxcbiAgICAgICAgY2FuYXJ5OiB7fSxcbiAgICAgICAgcHRiOiB7fVxuICAgICAgfSwgc2V0dGluZ3MpO1xuICAgICAgdGhpcy5zZXRCRERhdGEoXCJzZXR0aW5nc1wiLCBzZXR0aW5ncyk7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGVycik7XG4gICAgICBVdGlscy5hbGVydChcIkNvcnJ1cHQgU3RvcmFnZVwiLCBcIlRoZSBiZCBzdG9yYWdlIGhhcyBzb21laG93IGJlY29tZSBjb3JydXB0LiBZb3UgbWF5IGVpdGhlciB0cnkgdG8gc2FsdmFnZSB0aGUgZmlsZSBvciBkZWxldGUgaXQgdGhlbiByZWxvYWQuXCIpO1xuICAgIH1cbiAgfVxuXG4gIGdldCBpbmplY3Rpb25QYXRoKCkge1xuICAgIGlmICh0aGlzLl9pbmplY3Rpb25QYXRoKSByZXR1cm4gdGhpcy5faW5qZWN0aW9uUGF0aDtcblxuICAgIGNvbnN0IGVsZWN0cm9uID0gcmVxdWlyZShcImVsZWN0cm9uXCIpLnJlbW90ZS5hcHA7XG5cbiAgICBjb25zdCBiYXNlID0gZWxlY3Ryb24uZ2V0QXBwUGF0aCgpO1xuICAgIGNvbnN0IHJvYW1pbmdCYXNlID0gZWxlY3Ryb24uZ2V0UGF0aChcInVzZXJEYXRhXCIpO1xuICAgIGNvbnN0IHJvYW1pbmdMb2NhdGlvbiA9IHBhdGgucmVzb2x2ZShyb2FtaW5nQmFzZSwgZWxlY3Ryb24uZ2V0VmVyc2lvbigpLCBcIm1vZHVsZXNcIiwgXCJkaXNjb3JkX2Rlc2t0b3BfY29yZVwiLCBcImluamVjdG9yXCIpO1xuICAgIGNvbnN0IGxvY2F0aW9uID0gcGF0aC5yZXNvbHZlKGJhc2UsIFwiLi5cIiwgXCJhcHBcIik7XG4gICAgY29uc3QgcmVhbExvY2F0aW9uID0gZnMuZXhpc3RzU3luYyhsb2NhdGlvbikgPyBsb2NhdGlvbiA6IGZzLmV4aXN0c1N5bmMocm9hbWluZ0xvY2F0aW9uKSA/IHJvYW1pbmdMb2NhdGlvbiA6IG51bGw7XG4gICAgaWYgKCFyZWFsTG9jYXRpb24pIHJldHVybiB0aGlzLl9pbmplY3Rpb25QYXRoID0gbnVsbDtcbiAgICByZXR1cm4gdGhpcy5faW5qZWN0aW9uUGF0aCA9IHJlYWxMb2NhdGlvbjtcbiAgfVxuXG4gIGdldCBjb25maWdGaWxlKCkge1xuICAgIHJldHVybiB0aGlzLl9jb25maWdGaWxlIHx8ICh0aGlzLl9jb25maWdGaWxlID0gcGF0aC5yZXNvbHZlKHRoaXMuaW5qZWN0aW9uUGF0aCwgXCJiZXR0ZXJkaXNjb3JkXCIsIFwiY29uZmlnLmpzb25cIikpO1xuICB9XG5cbiAgZ2V0IEJERmlsZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fQkRGaWxlIHx8ICh0aGlzLl9CREZpbGUgPSBwYXRoLnJlc29sdmUoYmRDb25maWcuZGF0YVBhdGgsIFwiYmRzdG9yYWdlLmpzb25cIikpO1xuICB9XG5cbiAgZ2V0IHNldHRpbmdzRmlsZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fc2V0dGluZ3NGaWxlIHx8ICh0aGlzLl9zZXR0aW5nc0ZpbGUgPSBwYXRoLnJlc29sdmUoYmRDb25maWcuZGF0YVBhdGgsIFwiYmRzZXR0aW5ncy5qc29uXCIpKTtcbiAgfVxuXG4gIGdldFBsdWdpbkZpbGUocGx1Z2luTmFtZSkge1xuICAgIHJldHVybiBwYXRoLnJlc29sdmUoQ29udGVudE1hbmFnZXIucGx1Z2luc0ZvbGRlciwgcGx1Z2luTmFtZSArIFwiLmNvbmZpZy5qc29uXCIpO1xuICB9XG5cbiAgZ2V0U2V0dGluZ0dyb3VwKGtleSkge1xuICAgIHJldHVybiB0aGlzLmRhdGEuc2V0dGluZ3NbcmVsZWFzZUNoYW5uZWxdW2tleV0gfHwgbnVsbDtcbiAgfVxuXG4gIHNldFNldHRpbmdHcm91cChrZXksIGRhdGEpIHtcbiAgICB0aGlzLmRhdGEuc2V0dGluZ3NbcmVsZWFzZUNoYW5uZWxdW2tleV0gPSBkYXRhO1xuICAgIGZzLndyaXRlRmlsZVN5bmModGhpcy5CREZpbGUsIEpTT04uc3RyaW5naWZ5KHRoaXMuZGF0YSwgbnVsbCwgNCksIFwiYmluYXJ5XCIpO1xuICB9XG5cbiAgZ2V0QkREYXRhKGtleSkge1xuICAgIHJldHVybiB0aGlzLmRhdGFba2V5XSB8fCBcIlwiO1xuICB9XG5cbiAgc2V0QkREYXRhKGtleSwgdmFsdWUpIHtcbiAgICB0aGlzLmRhdGFba2V5XSA9IHZhbHVlO1xuICAgIGZzLndyaXRlRmlsZVN5bmModGhpcy5CREZpbGUsIEpTT04uc3RyaW5naWZ5KHRoaXMuZGF0YSwgbnVsbCwgNCksIFwiYmluYXJ5XCIpO1xuICB9XG5cbiAgZ2V0UGx1Z2luRGF0YShwbHVnaW5OYW1lLCBrZXkpIHtcbiAgICBpZiAodGhpcy5wbHVnaW5EYXRhW3BsdWdpbk5hbWVdICE9PSB1bmRlZmluZWQpIHJldHVybiB0aGlzLnBsdWdpbkRhdGFbcGx1Z2luTmFtZV1ba2V5XSB8fCB1bmRlZmluZWQ7XG4gICAgaWYgKCFmcy5leGlzdHNTeW5jKHRoaXMuZ2V0UGx1Z2luRmlsZShwbHVnaW5OYW1lKSkpIHJldHVybiB1bmRlZmluZWQ7XG4gICAgdGhpcy5wbHVnaW5EYXRhW3BsdWdpbk5hbWVdID0gSlNPTi5wYXJzZShmcy5yZWFkRmlsZVN5bmModGhpcy5nZXRQbHVnaW5GaWxlKHBsdWdpbk5hbWUpKSk7XG4gICAgcmV0dXJuIHRoaXMucGx1Z2luRGF0YVtwbHVnaW5OYW1lXVtrZXldIHx8IHVuZGVmaW5lZDtcbiAgfVxuXG4gIHNldFBsdWdpbkRhdGEocGx1Z2luTmFtZSwga2V5LCB2YWx1ZSkge1xuICAgIGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkKSByZXR1cm47XG4gICAgaWYgKHRoaXMucGx1Z2luRGF0YVtwbHVnaW5OYW1lXSA9PT0gdW5kZWZpbmVkKSB0aGlzLnBsdWdpbkRhdGFbcGx1Z2luTmFtZV0gPSB7fTtcbiAgICB0aGlzLnBsdWdpbkRhdGFbcGx1Z2luTmFtZV1ba2V5XSA9IHZhbHVlO1xuICAgIGZzLndyaXRlRmlsZVN5bmModGhpcy5nZXRQbHVnaW5GaWxlKHBsdWdpbk5hbWUpLCBKU09OLnN0cmluZ2lmeSh0aGlzLnBsdWdpbkRhdGFbcGx1Z2luTmFtZV0sIG51bGwsIDQpLCBcImJpbmFyeVwiKTtcbiAgfVxuXG4gIGRlbGV0ZVBsdWdpbkRhdGEocGx1Z2luTmFtZSwga2V5KSB7XG4gICAgaWYgKHRoaXMucGx1Z2luRGF0YVtwbHVnaW5OYW1lXSA9PT0gdW5kZWZpbmVkKSB0aGlzLnBsdWdpbkRhdGFbcGx1Z2luTmFtZV0gPSB7fTtcbiAgICBkZWxldGUgdGhpcy5wbHVnaW5EYXRhW3BsdWdpbk5hbWVdW2tleV07XG4gICAgZnMud3JpdGVGaWxlU3luYyh0aGlzLmdldFBsdWdpbkZpbGUocGx1Z2luTmFtZSksIEpTT04uc3RyaW5naWZ5KHRoaXMucGx1Z2luRGF0YVtwbHVnaW5OYW1lXSwgbnVsbCwgNCksIFwiYmluYXJ5XCIpO1xuICB9XG5cbn0oKTsiXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/modules/dataStore.js\n"); + +/***/ }), + +/***/ "./src/modules/devMode.js": +/*!********************************!*\ + !*** ./src/modules/devMode.js ***! + \********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _v2__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _domtools__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./domtools */ \"./src/modules/domtools.js\");\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class DevMode {\n constructor() {\n this.debugListener = this.debugListener.bind(this);\n this.copySelectorListener = this.copySelectorListener.bind(this);\n }\n\n start() {\n this.startDebugListener();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-dm-1\"]) this.startCopySelector();\n }\n\n stop() {\n this.stopDebugListener();\n this.stopCopySelector();\n }\n\n startDebugListener() {\n this.stopDebugListener();\n document.addEventListener(\"keydown\", this.debugListener);\n }\n\n stopDebugListener() {\n document.removeEventListener(\"keydown\", this.debugListener);\n }\n\n startCopySelector() {\n this.stopCopySelector();\n document.addEventListener(\"contextmenu\", this.copySelectorListener);\n }\n\n stopCopySelector() {\n document.removeEventListener(\"contextmenu\", this.copySelectorListener);\n }\n\n debugListener(e) {\n if (e.which === 119 || e.which == 118) {\n //F8\n console.log(\"%c[%cDevMode%c] %cBreak/Resume\", \"color: red;\", \"color: #303030; font-weight:700;\", \"color:red;\", \"\");\n debugger; // eslint-disable-line no-debugger\n\n e.preventDefault();\n e.stopImmediatePropagation();\n }\n }\n\n copySelectorListener(e) {\n try {\n e.stopPropagation();\n const selector = this.getSelector(e.target);\n let [classNameLayer, classItems] = [BDModules.get(e => e.layer && typeof e.layer === \"string\" && e.disabledPointerEvents)[0].layer, BDModules.get(e => e.contextMenu)[0]];\n\n function attach() {\n let cm = _domtools__WEBPACK_IMPORTED_MODULE_2__[\"default\"].query(\".\" + classItems.contextMenu.split(\" \")[0]);\n\n if (!cm) {\n const container = _domtools__WEBPACK_IMPORTED_MODULE_2__[\"default\"].query(\"#app-mount\");\n const cmWrap = _domtools__WEBPACK_IMPORTED_MODULE_2__[\"default\"].createElement(`
`);\n cm = _domtools__WEBPACK_IMPORTED_MODULE_2__[\"default\"].createElement(`
`);\n cmWrap.append(cm);\n container.append(cmWrap);\n cmWrap.style.top = e.clientY + \"px\";\n cmWrap.style.left = e.clientX + \"px\";\n cmWrap.style.zIndex = \"1002\";\n\n const removeCM = function (e) {\n if (e.keyCode && e.keyCode !== 27) return;\n cmWrap.remove();\n document.removeEventListener(\"click\", removeCM);\n document.removeEventListener(\"contextmenu\", removeCM);\n document.removeEventListener(\"keyup\", removeCM);\n };\n\n document.addEventListener(\"click\", removeCM);\n document.addEventListener(\"contextmenu\", removeCM);\n document.addEventListener(\"keyup\", removeCM);\n }\n\n const cmWrap = _domtools__WEBPACK_IMPORTED_MODULE_2__[\"default\"].query(\".\" + classNameLayer.split(\" \")[0]);\n const cmg = _domtools__WEBPACK_IMPORTED_MODULE_2__[\"default\"].createElement(`
`);\n const cmi = _domtools__WEBPACK_IMPORTED_MODULE_2__[\"default\"].createElement(`
`);\n cmi.append(_domtools__WEBPACK_IMPORTED_MODULE_2__[\"default\"].createElement(`
Copy Selector
`));\n cmi.addEventListener(\"click\", () => {\n _v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].NativeModule.copy(selector);\n cm.style.display = \"none\";\n });\n cmg.append(cmi);\n cm.append(cmg);\n\n if (cmWrap.clientHeight < cmWrap.scrollHeight) {\n console.log(\"overflowing \" + cmWrap.style.top);\n cmWrap.style.top = cmWrap.style.top - cmg.clientHeight + \"px\";\n console.log(\"overflowing\" + cmWrap.style.top);\n }\n }\n\n process.nextTick(attach);\n } catch (e) {\n console.error(e);\n }\n }\n\n getSelector(element) {\n if (element.id) return `#${element.id}`;\n /**\r\n * \r\n * @param {HTMLElement} el \r\n */\n\n function fullPath(el) {\n var names = [];\n\n while (el.parentNode) {\n if (el.id) {\n names.unshift('#' + el.id);\n break;\n } else {\n if (el == el.ownerDocument.documentElement) names.unshift(el.tagName.toLowerCase() + Array.from(el.classList.entries()).map(e => \".\" + e).join(\"\"));else {\n for (var c = 1, e = el; e.previousElementSibling; e = e.previousElementSibling, c++);\n\n names.unshift(el.tagName.toLowerCase() + (el.className || \"\").split(\" \").map(e => \".\" + e).join(\"\") + \":nth-child(\" + c + \")\");\n }\n el = el.parentNode;\n }\n }\n\n return names.join(\" > \");\n }\n\n return fullPath(element);\n /*\r\n const rules = this.getRules(element);\r\n const latestRule = rules[rules.length - 1];\r\n if (latestRule) return latestRule.selectorText;\r\n else if (element.classList.length) return `.${Array.from(element.classList).join(\".\")}`;\r\n return `.${Array.from(element.parentElement.classList).join(\".\")}`;*/\n }\n\n getRules(element, css = element.ownerDocument.styleSheets) {\n //if (window.getMatchedCSSRules) return window.getMatchedCSSRules(element);\n const sheets = [...css].filter(s => !s.href || !s.href.includes(\"BetterDiscordApp\"));\n const rules = sheets.map(s => [...(s.cssRules || [])]).flat();\n const elementRules = rules.filter(r => r && r.selectorText && element.matches(r.selectorText) && r.style.length && r.selectorText.split(\", \").length < 8 && !r.selectorText.split(\", \").includes(\"*\"));\n return elementRules;\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/modules/devMode.js.js","sources":["webpack://BetterDiscord/./src/modules/devMode.js?944c"],"sourcesContent":["import { settingsCookie } from \"../0globals\";\nimport BDV2 from \"./v2\";\nimport DOM from \"./domtools\";\nexport default new class DevMode {\n  constructor() {\n    this.debugListener = this.debugListener.bind(this);\n    this.copySelectorListener = this.copySelectorListener.bind(this);\n  }\n\n  start() {\n    this.startDebugListener();\n    if (settingsCookie[\"fork-dm-1\"]) this.startCopySelector();\n  }\n\n  stop() {\n    this.stopDebugListener();\n    this.stopCopySelector();\n  }\n\n  startDebugListener() {\n    this.stopDebugListener();\n    document.addEventListener(\"keydown\", this.debugListener);\n  }\n\n  stopDebugListener() {\n    document.removeEventListener(\"keydown\", this.debugListener);\n  }\n\n  startCopySelector() {\n    this.stopCopySelector();\n    document.addEventListener(\"contextmenu\", this.copySelectorListener);\n  }\n\n  stopCopySelector() {\n    document.removeEventListener(\"contextmenu\", this.copySelectorListener);\n  }\n\n  debugListener(e) {\n    if (e.which === 119 || e.which == 118) {\n      //F8\n      console.log(\"%c[%cDevMode%c] %cBreak/Resume\", \"color: red;\", \"color: #303030; font-weight:700;\", \"color:red;\", \"\");\n      debugger; // eslint-disable-line no-debugger\n\n      e.preventDefault();\n      e.stopImmediatePropagation();\n    }\n  }\n\n  copySelectorListener(e) {\n    try {\n      e.stopPropagation();\n      const selector = this.getSelector(e.target);\n      let [classNameLayer, classItems] = [BDModules.get(e => e.layer && typeof e.layer === \"string\" && e.disabledPointerEvents)[0].layer, BDModules.get(e => e.contextMenu)[0]];\n\n      function attach() {\n        let cm = DOM.query(\".\" + classItems.contextMenu.split(\" \")[0]);\n\n        if (!cm) {\n          const container = DOM.query(\"#app-mount\");\n          const cmWrap = DOM.createElement(`<div class=\"${classNameLayer}\">`);\n          cm = DOM.createElement(`<div class=\"${classItems.contextMenu} bd-context-menu\"></div>`);\n          cmWrap.append(cm);\n          container.append(cmWrap);\n          cmWrap.style.top = e.clientY + \"px\";\n          cmWrap.style.left = e.clientX + \"px\";\n          cmWrap.style.zIndex = \"1002\";\n\n          const removeCM = function (e) {\n            if (e.keyCode && e.keyCode !== 27) return;\n            cmWrap.remove();\n            document.removeEventListener(\"click\", removeCM);\n            document.removeEventListener(\"contextmenu\", removeCM);\n            document.removeEventListener(\"keyup\", removeCM);\n          };\n\n          document.addEventListener(\"click\", removeCM);\n          document.addEventListener(\"contextmenu\", removeCM);\n          document.addEventListener(\"keyup\", removeCM);\n        }\n\n        const cmWrap = DOM.query(\".\" + classNameLayer.split(\" \")[0]);\n        const cmg = DOM.createElement(`<div class=\"${classItems.itemGroup}\">`);\n        const cmi = DOM.createElement(`<div class=\"${classItems.item} ${classItems.clickable}\">`);\n        cmi.append(DOM.createElement(`<div class=\"${classItems.label}\">Copy Selector</div>`));\n        cmi.addEventListener(\"click\", () => {\n          BDV2.NativeModule.copy(selector);\n          cm.style.display = \"none\";\n        });\n        cmg.append(cmi);\n        cm.append(cmg);\n\n        if (cmWrap.clientHeight < cmWrap.scrollHeight) {\n          console.log(\"overflowing \" + cmWrap.style.top);\n          cmWrap.style.top = cmWrap.style.top - cmg.clientHeight + \"px\";\n          console.log(\"overflowing\" + cmWrap.style.top);\n        }\n      }\n\n      process.nextTick(attach);\n    } catch (e) {\n      console.error(e);\n    }\n  }\n\n  getSelector(element) {\n    if (element.id) return `#${element.id}`;\n    /**\r\n     * \r\n     * @param {HTMLElement} el \r\n     */\n\n    function fullPath(el) {\n      var names = [];\n\n      while (el.parentNode) {\n        if (el.id) {\n          names.unshift('#' + el.id);\n          break;\n        } else {\n          if (el == el.ownerDocument.documentElement) names.unshift(el.tagName.toLowerCase() + Array.from(el.classList.entries()).map(e => \".\" + e).join(\"\"));else {\n            for (var c = 1, e = el; e.previousElementSibling; e = e.previousElementSibling, c++);\n\n            names.unshift(el.tagName.toLowerCase() + (el.className || \"\").split(\" \").map(e => \".\" + e).join(\"\") + \":nth-child(\" + c + \")\");\n          }\n          el = el.parentNode;\n        }\n      }\n\n      return names.join(\" > \");\n    }\n\n    return fullPath(element);\n    /*\r\n    const rules = this.getRules(element);\r\n    const latestRule = rules[rules.length - 1];\r\n    if (latestRule) return latestRule.selectorText;\r\n    else if (element.classList.length) return `.${Array.from(element.classList).join(\".\")}`;\r\n    return `.${Array.from(element.parentElement.classList).join(\".\")}`;*/\n  }\n\n  getRules(element, css = element.ownerDocument.styleSheets) {\n    //if (window.getMatchedCSSRules) return window.getMatchedCSSRules(element);\n    const sheets = [...css].filter(s => !s.href || !s.href.includes(\"BetterDiscordApp\"));\n    const rules = sheets.map(s => [...(s.cssRules || [])]).flat();\n    const elementRules = rules.filter(r => r && r.selectorText && element.matches(r.selectorText) && r.style.length && r.selectorText.split(\", \").length < 8 && !r.selectorText.split(\", \").includes(\"*\"));\n    return elementRules;\n  }\n\n}();"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/modules/devMode.js\n"); + +/***/ }), + +/***/ "./src/modules/domtools.js": +/*!*********************************!*\ + !*** ./src/modules/domtools.js ***! + \*********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return DOMTools; });\n/**\r\n * Copyright 2018 Zachary Rauen\r\n *\r\n * Permission is hereby granted, free of charge, to any person obtaining\r\n * a copy of this software and associated documentation files (the \"Software\"),\r\n * to deal in the Software without restriction, including without limitation the\r\n * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\n * copies of the Software, and to permit persons to whom the Software is furnished\r\n * to do so, subject to the following conditions:\r\n *\r\n * The above copyright notice and this permission notice shall be included in all\r\n * copies or substantial portions of the Software.\r\n *\r\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,\r\n * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A\r\n * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT\r\n * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF\r\n * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE\r\n * OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\r\n * \r\n * From: https://github.com/rauenzi/BDPluginLibrary\r\n */\n\n/**\r\n * @interface\r\n * @name Offset\r\n * @property {number} top - Top offset of the target element.\r\n * @property {number} right - Right offset of the target element.\r\n * @property {number} bottom - Bottom offset of the target element.\r\n * @property {number} left - Left offset of the target element.\r\n * @property {number} height - Outer height of the target element.\r\n * @property {number} width - Outer width of the target element.\r\n */\n\n/**\r\n* Function that automatically removes added listener.\r\n* @callback module:DOMTools~CancelListener\r\n*/\nclass DOMTools {\n static escapeID(id) {\n return id.replace(/^[^a-z]+|[^\\w-]+/gi, \"-\");\n }\n /**\r\n * Adds a style to the document.\r\n * @param {string} id - identifier to use as the element id\r\n * @param {string} css - css to add to the document\r\n */\n\n\n static addStyle(id, css) {\n document.head.append(DOMTools.createElement(``));\n }\n /**\r\n * Removes a style from the document.\r\n * @param {string} id - original identifier used\r\n */\n\n\n static removeStyle(id) {\n const element = document.getElementById(id);\n if (element) element.remove();\n }\n /**\r\n * Adds/requires a remote script to be loaded\r\n * @param {string} id - identifier to use for this script\r\n * @param {string} url - url from which to load the script\r\n * @returns {Promise} promise that resolves when the script is loaded\r\n */\n\n\n static addScript(id, url) {\n return new Promise(resolve => {\n const script = document.createElement(\"script\");\n script.id = id;\n script.src = url;\n script.type = \"text/javascript\";\n script.onload = resolve;\n document.head.append(script);\n });\n }\n /**\r\n * Removes a remote script from the document.\r\n * @param {string} id - original identifier used\r\n */\n\n\n static removeScript(id) {\n id = this.escapeID(id);\n const element = document.getElementById(id);\n if (element) element.remove();\n } // https://javascript.info/js-animation\n\n\n static animate({\n timing = _ => _,\n update,\n duration\n }) {\n const start = performance.now();\n requestAnimationFrame(function animate(time) {\n // timeFraction goes from 0 to 1\n let timeFraction = (time - start) / duration;\n if (timeFraction > 1) timeFraction = 1; // calculate the current animation state\n\n const progress = timing(timeFraction);\n update(progress); // draw it\n\n if (timeFraction < 1) {\n requestAnimationFrame(animate);\n }\n });\n }\n /**\r\n * This is my shit version of not having to use `$` from jQuery. Meaning\r\n * that you can pass a selector and it will automatically run {@link module:DOMTools.query}.\r\n * It also means that you can pass a string of html and it will perform and return `parseHTML`.\r\n * @see module:DOMTools.parseHTML\r\n * @see module:DOMTools.query\r\n * @param {string} selector - Selector to query or HTML to parse\r\n * @returns {(DocumentFragment|NodeList|HTMLElement)} - Either the result of `parseHTML` or `query`\r\n */\n\n\n static Q(selector) {\n const element = this.parseHTML(selector);\n const isHTML = element instanceof NodeList ? Array.from(element).some(n => n.nodeType === 1) : element.nodeType === 1;\n if (isHTML) return element;\n return this.query(selector);\n }\n /**\r\n * Essentially a shorthand for `document.querySelector`. If the `baseElement` is not provided\r\n * `document` is used by default.\r\n * @param {string} selector - Selector to query\r\n * @param {Element} [baseElement] - Element to base the query from\r\n * @returns {(Element|null)} - The found element or null if not found\r\n */\n\n\n static query(selector, baseElement) {\n if (!baseElement) baseElement = document;\n return baseElement.querySelector(selector);\n }\n /**\r\n * Essentially a shorthand for `document.querySelectorAll`. If the `baseElement` is not provided\r\n * `document` is used by default.\r\n * @param {string} selector - Selector to query\r\n * @param {Element} [baseElement] - Element to base the query from\r\n * @returns {Array} - Array of all found elements\r\n */\n\n\n static queryAll(selector, baseElement) {\n if (!baseElement) baseElement = document;\n return baseElement.querySelectorAll(selector);\n }\n /**\r\n * Parses a string of HTML and returns the results. If the second parameter is true,\r\n * the parsed HTML will be returned as a document fragment {@see https://developer.mozilla.org/en-US/docs/Web/API/DocumentFragment}.\r\n * This is extremely useful if you have a list of elements at the top level, they can then be appended all at once to another node.\r\n * \r\n * If the second parameter is false, then the return value will be the list of parsed\r\n * nodes and there were multiple top level nodes, otherwise the single node is returned.\r\n * @param {string} html - HTML to be parsed\r\n * @param {boolean} [fragment=false] - Whether or not the return should be the raw `DocumentFragment`\r\n * @returns {(DocumentFragment|NodeList|HTMLElement)} - The result of HTML parsing\r\n */\n\n\n static parseHTML(html, fragment = false) {\n const template = document.createElement(\"template\");\n template.innerHTML = html;\n const node = template.content.cloneNode(true);\n if (fragment) return node;\n return node.childNodes.length > 1 ? node.childNodes : node.childNodes[0];\n }\n /** Alternate name for {@link module:DOMTools.parseHTML} */\n\n\n static createElement(html, fragment = false) {\n return this.parseHTML(html, fragment);\n }\n /**\r\n * Takes a string of html and escapes it using the brower's own escaping mechanism.\r\n * @param {String} html - html to be escaped\r\n */\n\n\n static escapeHTML(html) {\n const textNode = document.createTextNode(\"\");\n const spanElement = document.createElement(\"span\");\n spanElement.append(textNode);\n textNode.nodeValue = html;\n return spanElement.innerHTML;\n }\n /**\r\n * Adds a list of classes from the target element.\r\n * @param {Element} element - Element to edit classes of\r\n * @param {...string} classes - Names of classes to add\r\n * @returns {Element} - `element` to allow for chaining\r\n */\n\n\n static addClass(element, ...classes) {\n classes = classes.flat().filter(c => c);\n\n for (let c = 0; c < classes.length; c++) classes[c] = classes[c].toString().split(\" \");\n\n classes = classes.flat().filter(c => c);\n element.classList.add(...classes);\n return element;\n }\n /**\r\n * Removes a list of classes from the target element.\r\n * @param {Element} element - Element to edit classes of\r\n * @param {...string} classes - Names of classes to remove\r\n * @returns {Element} - `element` to allow for chaining\r\n */\n\n\n static removeClass(element, ...classes) {\n for (let c = 0; c < classes.length; c++) classes[c] = classes[c].toString().split(\" \");\n\n classes = classes.flat().filter(c => c);\n element.classList.remove(...classes);\n return element;\n }\n /**\r\n * When only one argument is present: Toggle class value;\r\n * i.e., if class exists then remove it and return false, if not, then add it and return true.\r\n * When a second argument is present:\r\n * If the second argument evaluates to true, add specified class value, and if it evaluates to false, remove it.\r\n * @param {Element} element - Element to edit classes of\r\n * @param {string} classname - Name of class to toggle\r\n * @param {boolean} [indicator] - Optional indicator for if the class should be toggled\r\n * @returns {Element} - `element` to allow for chaining\r\n */\n\n\n static toggleClass(element, classname, indicator) {\n classname = classname.toString().split(\" \").filter(c => c);\n if (typeof indicator !== \"undefined\") classname.forEach(c => element.classList.toggle(c, indicator));else classname.forEach(c => element.classList.toggle(c));\n return element;\n }\n /**\r\n * Checks if an element has a specific class\r\n * @param {Element} element - Element to edit classes of\r\n * @param {string} classname - Name of class to check\r\n * @returns {boolean} - `true` if the element has the class, `false` otherwise.\r\n */\n\n\n static hasClass(element, classname) {\n return classname.toString().split(\" \").filter(c => c).every(c => element.classList.contains(c));\n }\n /**\r\n * Replaces one class with another\r\n * @param {Element} element - Element to edit classes of\r\n * @param {string} oldName - Name of class to replace\r\n * @param {string} newName - New name for the class\r\n * @returns {Element} - `element` to allow for chaining\r\n */\n\n\n static replaceClass(element, oldName, newName) {\n element.classList.replace(oldName, newName);\n return element;\n }\n /**\r\n * Appends `thisNode` to `thatNode`\r\n * @param {Node} thisNode - Node to be appended to another node\r\n * @param {Node} thatNode - Node for `thisNode` to be appended to\r\n * @returns {Node} - `thisNode` to allow for chaining\r\n */\n\n\n static appendTo(thisNode, thatNode) {\n if (typeof thatNode == \"string\") thatNode = this.query(thatNode);\n if (!thatNode) return null;\n thatNode.append(thisNode);\n return thisNode;\n }\n /**\r\n * Prepends `thisNode` to `thatNode`\r\n * @param {Node} thisNode - Node to be prepended to another node\r\n * @param {Node} thatNode - Node for `thisNode` to be prepended to\r\n * @returns {Node} - `thisNode` to allow for chaining\r\n */\n\n\n static prependTo(thisNode, thatNode) {\n if (typeof thatNode == \"string\") thatNode = this.query(thatNode);\n if (!thatNode) return null;\n thatNode.prepend(thisNode);\n return thisNode;\n }\n /**\r\n * Insert after a specific element, similar to jQuery's `thisElement.insertAfter(otherElement)`.\r\n * @param {Node} thisNode - The node to insert\r\n * @param {Node} targetNode - Node to insert after in the tree\r\n * @returns {Node} - `thisNode` to allow for chaining\r\n */\n\n\n static insertAfter(thisNode, targetNode) {\n targetNode.parentNode.insertBefore(thisNode, targetNode.nextSibling);\n return thisNode;\n }\n /**\r\n * Insert after a specific element, similar to jQuery's `thisElement.after(newElement)`.\r\n * @param {Node} thisNode - The node to insert\r\n * @param {Node} newNode - Node to insert after in the tree\r\n * @returns {Node} - `thisNode` to allow for chaining\r\n */\n\n\n static after(thisNode, newNode) {\n thisNode.parentNode.insertBefore(newNode, thisNode.nextSibling);\n return thisNode;\n }\n /**\r\n * Gets the next sibling element that matches the selector.\r\n * @param {Element} element - Element to get the next sibling of\r\n * @param {string} [selector=\"\"] - Optional selector\r\n * @returns {Element} - The sibling element\r\n */\n\n\n static next(element, selector = \"\") {\n return selector ? element.querySelector(\"+ \" + selector) : element.nextElementSibling;\n }\n /**\r\n * Gets all subsequent siblings.\r\n * @param {Element} element - Element to get next siblings of\r\n * @returns {NodeList} - The list of siblings\r\n */\n\n\n static nextAll(element) {\n return element.querySelectorAll(\"~ *\");\n }\n /**\r\n * Gets the subsequent siblings until an element matches the selector.\r\n * @param {Element} element - Element to get the following siblings of\r\n * @param {string} selector - Selector to stop at\r\n * @returns {Array} - The list of siblings\r\n */\n\n\n static nextUntil(element, selector) {\n const next = [];\n\n while (element.nextElementSibling && !element.nextElementSibling.matches(selector)) next.push(element = element.nextElementSibling);\n\n return next;\n }\n /**\r\n * Gets the previous sibling element that matches the selector.\r\n * @param {Element} element - Element to get the previous sibling of\r\n * @param {string} [selector=\"\"] - Optional selector\r\n * @returns {Element} - The sibling element\r\n */\n\n\n static previous(element, selector = \"\") {\n const previous = element.previousElementSibling;\n if (selector) return previous && previous.matches(selector) ? previous : null;\n return previous;\n }\n /**\r\n * Gets all preceeding siblings.\r\n * @param {Element} element - Element to get preceeding siblings of\r\n * @returns {NodeList} - The list of siblings\r\n */\n\n\n static previousAll(element) {\n const previous = [];\n\n while (element.previousElementSibling) previous.push(element = element.previousElementSibling);\n\n return previous;\n }\n /**\r\n * Gets the preceeding siblings until an element matches the selector.\r\n * @param {Element} element - Element to get the preceeding siblings of\r\n * @param {string} selector - Selector to stop at\r\n * @returns {Array} - The list of siblings\r\n */\n\n\n static previousUntil(element, selector) {\n const previous = [];\n\n while (element.previousElementSibling && !element.previousElementSibling.matches(selector)) previous.push(element = element.previousElementSibling);\n\n return previous;\n }\n /**\r\n * Find which index in children a certain node is. Similar to jQuery's `$.index()`\r\n * @param {HTMLElement} node - The node to find its index in parent\r\n * @returns {number} Index of the node\r\n */\n\n\n static indexInParent(node) {\n const children = node.parentNode.childNodes;\n let num = 0;\n\n for (let i = 0; i < children.length; i++) {\n if (children[i] == node) return num;\n if (children[i].nodeType == 1) num++;\n }\n\n return -1;\n }\n /** Shorthand for {@link module:DOMTools.indexInParent} */\n\n\n static index(node) {\n return this.indexInParent(node);\n }\n /**\r\n * Gets the parent of the element if it matches the selector,\r\n * otherwise returns null.\r\n * @param {Element} element - Element to get parent of\r\n * @param {string} [selector=\"\"] - Selector to match parent\r\n * @returns {(Element|null)} - The sibling element or null\r\n */\n\n\n static parent(element, selector = \"\") {\n return !selector || element.parentElement.matches(selector) ? element.parentElement : null;\n }\n /**\r\n * Gets all children of Element that match the selector if provided.\r\n * @param {Element} element - Element to get all children of\r\n * @param {string} selector - Selector to match the children to\r\n * @returns {Array} - The list of children\r\n */\n\n\n static findChild(element, selector) {\n return element.querySelector(\":scope > \" + selector);\n }\n /**\r\n * Gets all children of Element that match the selector if provided.\r\n * @param {Element} element - Element to get all children of\r\n * @param {string} selector - Selector to match the children to\r\n * @returns {Array} - The list of children\r\n */\n\n\n static findChildren(element, selector) {\n return element.querySelectorAll(\":scope > \" + selector);\n }\n /**\r\n * Gets all ancestors of Element that match the selector if provided.\r\n * @param {Element} element - Element to get all parents of\r\n * @param {string} [selector=\"\"] - Selector to match the parents to\r\n * @returns {Array} - The list of parents\r\n */\n\n\n static parents(element, selector = \"\") {\n const parents = [];\n if (selector) while (element.parentElement && element.parentElement.closest(selector)) parents.push(element = element.parentElement.closest(selector));else while (element.parentElement) parents.push(element = element.parentElement);\n return parents;\n }\n /**\r\n * Gets the ancestors until an element matches the selector.\r\n * @param {Element} element - Element to get the ancestors of\r\n * @param {string} selector - Selector to stop at\r\n * @returns {Array} - The list of parents\r\n */\n\n\n static parentsUntil(element, selector) {\n const parents = [];\n\n while (element.parentElement && !element.parentElement.matches(selector)) parents.push(element = element.parentElement);\n\n return parents;\n }\n /**\r\n * Gets all siblings of the element that match the selector.\r\n * @param {Element} element - Element to get all siblings of\r\n * @param {string} [selector=\"*\"] - Selector to match the siblings to\r\n * @returns {Array} - The list of siblings\r\n */\n\n\n static siblings(element, selector = \"*\") {\n return Array.from(element.parentElement.children).filter(e => e != element && e.matches(selector));\n }\n /**\r\n * Sets or gets css styles for a specific element. If `value` is provided\r\n * then it sets the style and returns the element to allow for chaining,\r\n * otherwise returns the style. \r\n * @param {Element} element - Element to set the CSS of\r\n * @param {string} attribute - Attribute to get or set\r\n * @param {string} [value] - Value to set for attribute\r\n * @returns {Element|string} - When setting a value, element is returned for chaining, otherwise the value is returned.\r\n */\n\n\n static css(element, attribute, value) {\n if (typeof value == \"undefined\") return global.getComputedStyle(element)[attribute];\n element.style[attribute] = value;\n return element;\n }\n /**\r\n * Sets or gets the width for a specific element. If `value` is provided\r\n * then it sets the width and returns the element to allow for chaining,\r\n * otherwise returns the width. \r\n * @param {Element} element - Element to set the CSS of\r\n * @param {string} [value] - Width to set\r\n * @returns {Element|string} - When setting a value, element is returned for chaining, otherwise the value is returned.\r\n */\n\n\n static width(element, value) {\n if (typeof value == \"undefined\") return parseInt(getComputedStyle(element).width);\n element.style.width = value;\n return element;\n }\n /**\r\n * Sets or gets the height for a specific element. If `value` is provided\r\n * then it sets the height and returns the element to allow for chaining,\r\n * otherwise returns the height. \r\n * @param {Element} element - Element to set the CSS of\r\n * @param {string} [value] - Height to set\r\n * @returns {Element|string} - When setting a value, element is returned for chaining, otherwise the value is returned.\r\n */\n\n\n static height(element, value) {\n if (typeof value == \"undefined\") return parseInt(getComputedStyle(element).height);\n element.style.height = value;\n return element;\n }\n /**\r\n * Sets the inner text of an element if given a value, otherwise returns it.\r\n * @param {Element} element - Element to set the text of\r\n * @param {string} [text] - Content to set\r\n * @returns {string} - Either the string set by this call or the current text content of the node.\r\n */\n\n\n static text(element, text) {\n if (typeof text == \"undefined\") return element.textContent;\n return element.textContent = text;\n }\n /**\r\n * Returns the innerWidth of the element.\r\n * @param {Element} element - Element to retrieve inner width of\r\n * @return {number} - The inner width of the element.\r\n */\n\n\n static innerWidth(element) {\n return element.clientWidth;\n }\n /**\r\n * Returns the innerHeight of the element.\r\n * @param {Element} element - Element to retrieve inner height of\r\n * @return {number} - The inner height of the element.\r\n */\n\n\n static innerHeight(element) {\n return element.clientHeight;\n }\n /**\r\n * Returns the outerWidth of the element.\r\n * @param {Element} element - Element to retrieve outer width of\r\n * @return {number} - The outer width of the element.\r\n */\n\n\n static outerWidth(element) {\n return element.offsetWidth;\n }\n /**\r\n * Returns the outerHeight of the element.\r\n * @param {Element} element - Element to retrieve outer height of\r\n * @return {number} - The outer height of the element.\r\n */\n\n\n static outerHeight(element) {\n return element.offsetHeight;\n }\n /**\r\n * Gets the offset of the element in the page.\r\n * @param {Element} element - Element to get offset of\r\n * @return {Offset} - The offset of the element\r\n */\n\n\n static offset(element) {\n return element.getBoundingClientRect();\n }\n\n static get listeners() {\n return this._listeners || (this._listeners = {});\n }\n /**\r\n * This is similar to jQuery's `on` function and can *hopefully* be used in the same way.\r\n * \r\n * Rather than attempt to explain, I'll show some example usages.\r\n * \r\n * The following will add a click listener (in the `myPlugin` namespace) to `element`.\r\n * `DOMTools.on(element, \"click.myPlugin\", () => {console.log(\"clicked!\");});`\r\n * \r\n * The following will add a click listener (in the `myPlugin` namespace) to `element` that only fires when the target is a `.block` element.\r\n * `DOMTools.on(element, \"click.myPlugin\", \".block\", () => {console.log(\"clicked!\");});`\r\n * \r\n * The following will add a click listener (without namespace) to `element`.\r\n * `DOMTools.on(element, \"click\", () => {console.log(\"clicked!\");});`\r\n * \r\n * The following will add a click listener (without namespace) to `element` that only fires once.\r\n * `const cancel = DOMTools.on(element, \"click\", () => {console.log(\"fired!\"); cancel();});`\r\n * \r\n * @param {Element} element - Element to add listener to\r\n * @param {string} event - Event to listen to with option namespace (e.g. \"event.namespace\")\r\n * @param {(string|callable)} delegate - Selector to run on element to listen to\r\n * @param {callable} [callback] - Function to fire on event\r\n * @returns {module:DOMTools~CancelListener} - A function that will undo the listener\r\n */\n\n\n static on(element, event, delegate, callback) {\n const [type, namespace] = event.split(\".\");\n const hasDelegate = delegate && callback;\n if (!callback) callback = delegate;\n const eventFunc = !hasDelegate ? callback : function (event) {\n if (event.target.matches(delegate)) {\n callback(event);\n }\n };\n element.addEventListener(type, eventFunc);\n\n const cancel = () => {\n element.removeEventListener(type, eventFunc);\n };\n\n if (namespace) {\n if (!this.listeners[namespace]) this.listeners[namespace] = [];\n\n const newCancel = () => {\n cancel();\n this.listeners[namespace].splice(this.listeners[namespace].findIndex(l => l.event == type && l.element == element), 1);\n };\n\n this.listeners[namespace].push({\n event: type,\n element: element,\n cancel: newCancel\n });\n return newCancel;\n }\n\n return cancel;\n }\n /**\r\n * Functionality for this method matches {@link module:DOMTools.on} but automatically cancels itself\r\n * and removes the listener upon the first firing of the desired event.\r\n * \r\n * @param {Element} element - Element to add listener to\r\n * @param {string} event - Event to listen to with option namespace (e.g. \"event.namespace\")\r\n * @param {(string|callable)} delegate - Selector to run on element to listen to\r\n * @param {callable} [callback] - Function to fire on event\r\n * @returns {module:DOMTools~CancelListener} - A function that will undo the listener\r\n */\n\n\n static once(element, event, delegate, callback) {\n const [type, namespace] = event.split(\".\");\n const hasDelegate = delegate && callback;\n if (!callback) callback = delegate;\n const eventFunc = !hasDelegate ? function (event) {\n callback(event);\n element.removeEventListener(type, eventFunc);\n } : function (event) {\n if (!event.target.matches(delegate)) return;\n callback(event);\n element.removeEventListener(type, eventFunc);\n };\n element.addEventListener(type, eventFunc);\n\n const cancel = () => {\n element.removeEventListener(type, eventFunc);\n };\n\n if (namespace) {\n if (!this.listeners[namespace]) this.listeners[namespace] = [];\n\n const newCancel = () => {\n cancel();\n this.listeners[namespace].splice(this.listeners[namespace].findIndex(l => l.event == type && l.element == element), 1);\n };\n\n this.listeners[namespace].push({\n event: type,\n element: element,\n cancel: newCancel\n });\n return newCancel;\n }\n\n return cancel;\n }\n\n static __offAll(event, element) {\n const [type, namespace] = event.split(\".\");\n\n let matchFilter = listener => listener.event == type,\n defaultFilter = _ => _;\n\n if (element) matchFilter = l => l.event == type && l.element == element, defaultFilter = l => l.element == element;\n const listeners = this.listeners[namespace] || [];\n const list = type ? listeners.filter(matchFilter) : listeners.filter(defaultFilter);\n\n for (let c = 0; c < list.length; c++) list[c].cancel();\n }\n /**\r\n * This is similar to jQuery's `off` function and can *hopefully* be used in the same way.\r\n * \r\n * Rather than attempt to explain, I'll show some example usages.\r\n * \r\n * The following will remove a click listener called `onClick` (in the `myPlugin` namespace) from `element`.\r\n * `DOMTools.off(element, \"click.myPlugin\", onClick);`\r\n * \r\n * The following will remove a click listener called `onClick` (in the `myPlugin` namespace) from `element` that only fired when the target is a `.block` element.\r\n * `DOMTools.off(element, \"click.myPlugin\", \".block\", onClick);`\r\n * \r\n * The following will remove a click listener (without namespace) from `element`.\r\n * `DOMTools.off(element, \"click\", onClick);`\r\n * \r\n * The following will remove all listeners in namespace `myPlugin` from `element`.\r\n * `DOMTools.off(element, \".myPlugin\");`\r\n * \r\n * The following will remove all click listeners in namespace `myPlugin` from *all elements*.\r\n * `DOMTools.off(\"click.myPlugin\");`\r\n * \r\n * The following will remove all listeners in namespace `myPlugin` from *all elements*.\r\n * `DOMTools.off(\".myPlugin\");`\r\n * \r\n * @param {(Element|string)} element - Element to remove listener from\r\n * @param {string} [event] - Event to listen to with option namespace (e.g. \"event.namespace\")\r\n * @param {(string|callable)} [delegate] - Selector to run on element to listen to\r\n * @param {callable} [callback] - Function to fire on event\r\n * @returns {Element} - The original element to allow for chaining\r\n */\n\n\n static off(element, event, delegate, callback) {\n if (typeof element == \"string\") return this.__offAll(element);\n const [type, namespace] = event.split(\".\");\n if (namespace) return this.__offAll(event, element);\n const hasDelegate = delegate && callback;\n if (!callback) callback = delegate;\n const eventFunc = !hasDelegate ? callback : function (event) {\n if (event.target.matches(delegate)) {\n callback(event);\n }\n };\n element.removeEventListener(type, eventFunc);\n return element;\n }\n /**\r\n * Adds a listener for when the node is added/removed from the document body.\r\n * The listener is automatically removed upon firing.\r\n * @param {HTMLElement} node - node to wait for\r\n * @param {callable} callback - function to be performed on event\r\n * @param {boolean} onMount - determines if it should fire on Mount or on Unmount\r\n */\n\n\n static onMountChange(node, callback, onMount = true) {\n const wrappedCallback = () => {\n this.observer.unsubscribe(wrappedCallback);\n callback();\n };\n\n this.observer.subscribe(wrappedCallback, mutation => {\n const nodes = Array.from(onMount ? mutation.addedNodes : mutation.removedNodes);\n const directMatch = nodes.indexOf(node) > -1;\n const parentMatch = nodes.some(parent => parent.contains(node));\n return directMatch || parentMatch;\n });\n return node;\n }\n /** Shorthand for {@link module:DOMTools.onMountChange} with third parameter `true` */\n\n\n static onMount(node, callback) {\n return this.onMountChange(node, callback);\n }\n /** Shorthand for {@link module:DOMTools.onMountChange} with third parameter `false` */\n\n\n static onUnmount(node, callback) {\n return this.onMountChange(node, callback, false);\n }\n /** Alias for {@link module:DOMTools.onMount} */\n\n\n static onAdded(node, callback) {\n return this.onMount(node, callback);\n }\n /** Alias for {@link module:DOMTools.onUnmount} */\n\n\n static onRemoved(node, callback) {\n return this.onUnmount(node, callback, false);\n }\n /**\r\n * Helper function which combines multiple elements into one parent element\r\n * @param {Array} elements - array of elements to put into a single parent\r\n */\n\n\n static wrap(elements) {\n const domWrapper = this.parseHTML(`
`);\n\n for (let e = 0; e < elements.length; e++) domWrapper.appendChild(elements[e]);\n\n return domWrapper;\n }\n /**\r\n * Resolves the node to an HTMLElement. This is mainly used by library modules.\r\n * @param {(jQuery|Element)} node - node to resolve\r\n */\n\n\n static resolveElement(node) {\n if (!(node instanceof jQuery) && !(node instanceof Element)) return undefined;\n return node instanceof jQuery ? node[0] : node;\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/modules/domtools.js.js","sources":["webpack://BetterDiscord/./src/modules/domtools.js?687d"],"sourcesContent":["/**\r\n * Copyright 2018 Zachary Rauen\r\n *\r\n * Permission is hereby granted, free of charge, to any person obtaining\r\n * a copy of this software and associated documentation files (the \"Software\"),\r\n * to deal in the Software without restriction, including without limitation the\r\n * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\r\n * copies of the Software, and to permit persons to whom the Software is furnished\r\n * to do so, subject to the following conditions:\r\n *\r\n * The above copyright notice and this permission notice shall be included in all\r\n * copies or substantial portions of the Software.\r\n *\r\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,\r\n * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A\r\n * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT\r\n * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF\r\n * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE\r\n * OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\r\n * \r\n * From: https://github.com/rauenzi/BDPluginLibrary\r\n */\n\n/**\r\n * @interface\r\n * @name Offset\r\n * @property {number} top - Top offset of the target element.\r\n * @property {number} right - Right offset of the target element.\r\n * @property {number} bottom - Bottom offset of the target element.\r\n * @property {number} left - Left offset of the target element.\r\n * @property {number} height - Outer height of the target element.\r\n * @property {number} width - Outer width of the target element.\r\n */\n\n/**\r\n* Function that automatically removes added listener.\r\n* @callback module:DOMTools~CancelListener\r\n*/\nexport default class DOMTools {\n  static escapeID(id) {\n    return id.replace(/^[^a-z]+|[^\\w-]+/gi, \"-\");\n  }\n  /**\r\n  * Adds a style to the document.\r\n  * @param {string} id - identifier to use as the element id\r\n  * @param {string} css - css to add to the document\r\n  */\n\n\n  static addStyle(id, css) {\n    document.head.append(DOMTools.createElement(`<style id=\"${id}\">${css}</style>`));\n  }\n  /**\r\n   * Removes a style from the document.\r\n   * @param {string} id - original identifier used\r\n   */\n\n\n  static removeStyle(id) {\n    const element = document.getElementById(id);\n    if (element) element.remove();\n  }\n  /**\r\n   * Adds/requires a remote script to be loaded\r\n   * @param {string} id - identifier to use for this script\r\n   * @param {string} url - url from which to load the script\r\n   * @returns {Promise} promise that resolves when the script is loaded\r\n   */\n\n\n  static addScript(id, url) {\n    return new Promise(resolve => {\n      const script = document.createElement(\"script\");\n      script.id = id;\n      script.src = url;\n      script.type = \"text/javascript\";\n      script.onload = resolve;\n      document.head.append(script);\n    });\n  }\n  /**\r\n   * Removes a remote script from the document.\r\n   * @param {string} id - original identifier used\r\n   */\n\n\n  static removeScript(id) {\n    id = this.escapeID(id);\n    const element = document.getElementById(id);\n    if (element) element.remove();\n  } // https://javascript.info/js-animation\n\n\n  static animate({\n    timing = _ => _,\n    update,\n    duration\n  }) {\n    const start = performance.now();\n    requestAnimationFrame(function animate(time) {\n      // timeFraction goes from 0 to 1\n      let timeFraction = (time - start) / duration;\n      if (timeFraction > 1) timeFraction = 1; // calculate the current animation state\n\n      const progress = timing(timeFraction);\n      update(progress); // draw it\n\n      if (timeFraction < 1) {\n        requestAnimationFrame(animate);\n      }\n    });\n  }\n  /**\r\n   * This is my shit version of not having to use `$` from jQuery. Meaning\r\n   * that you can pass a selector and it will automatically run {@link module:DOMTools.query}.\r\n   * It also means that you can pass a string of html and it will perform and return `parseHTML`.\r\n   * @see module:DOMTools.parseHTML\r\n   * @see module:DOMTools.query\r\n   * @param {string} selector - Selector to query or HTML to parse\r\n   * @returns {(DocumentFragment|NodeList|HTMLElement)} - Either the result of `parseHTML` or `query`\r\n   */\n\n\n  static Q(selector) {\n    const element = this.parseHTML(selector);\n    const isHTML = element instanceof NodeList ? Array.from(element).some(n => n.nodeType === 1) : element.nodeType === 1;\n    if (isHTML) return element;\n    return this.query(selector);\n  }\n  /**\r\n   * Essentially a shorthand for `document.querySelector`. If the `baseElement` is not provided\r\n   * `document` is used by default.\r\n   * @param {string} selector - Selector to query\r\n   * @param {Element} [baseElement] - Element to base the query from\r\n   * @returns {(Element|null)} - The found element or null if not found\r\n   */\n\n\n  static query(selector, baseElement) {\n    if (!baseElement) baseElement = document;\n    return baseElement.querySelector(selector);\n  }\n  /**\r\n   * Essentially a shorthand for `document.querySelectorAll`. If the `baseElement` is not provided\r\n   * `document` is used by default.\r\n   * @param {string} selector - Selector to query\r\n   * @param {Element} [baseElement] - Element to base the query from\r\n   * @returns {Array<Element>} - Array of all found elements\r\n   */\n\n\n  static queryAll(selector, baseElement) {\n    if (!baseElement) baseElement = document;\n    return baseElement.querySelectorAll(selector);\n  }\n  /**\r\n   * Parses a string of HTML and returns the results. If the second parameter is true,\r\n   * the parsed HTML will be returned as a document fragment {@see https://developer.mozilla.org/en-US/docs/Web/API/DocumentFragment}.\r\n   * This is extremely useful if you have a list of elements at the top level, they can then be appended all at once to another node.\r\n   * \r\n   * If the second parameter is false, then the return value will be the list of parsed\r\n   * nodes and there were multiple top level nodes, otherwise the single node is returned.\r\n   * @param {string} html - HTML to be parsed\r\n   * @param {boolean} [fragment=false] - Whether or not the return should be the raw `DocumentFragment`\r\n   * @returns {(DocumentFragment|NodeList|HTMLElement)} - The result of HTML parsing\r\n   */\n\n\n  static parseHTML(html, fragment = false) {\n    const template = document.createElement(\"template\");\n    template.innerHTML = html;\n    const node = template.content.cloneNode(true);\n    if (fragment) return node;\n    return node.childNodes.length > 1 ? node.childNodes : node.childNodes[0];\n  }\n  /** Alternate name for {@link module:DOMTools.parseHTML} */\n\n\n  static createElement(html, fragment = false) {\n    return this.parseHTML(html, fragment);\n  }\n  /**\r\n   * Takes a string of html and escapes it using the brower's own escaping mechanism.\r\n   * @param {String} html - html to be escaped\r\n   */\n\n\n  static escapeHTML(html) {\n    const textNode = document.createTextNode(\"\");\n    const spanElement = document.createElement(\"span\");\n    spanElement.append(textNode);\n    textNode.nodeValue = html;\n    return spanElement.innerHTML;\n  }\n  /**\r\n   * Adds a list of classes from the target element.\r\n   * @param {Element} element - Element to edit classes of\r\n   * @param {...string} classes - Names of classes to add\r\n   * @returns {Element} - `element` to allow for chaining\r\n   */\n\n\n  static addClass(element, ...classes) {\n    classes = classes.flat().filter(c => c);\n\n    for (let c = 0; c < classes.length; c++) classes[c] = classes[c].toString().split(\" \");\n\n    classes = classes.flat().filter(c => c);\n    element.classList.add(...classes);\n    return element;\n  }\n  /**\r\n   * Removes a list of classes from the target element.\r\n   * @param {Element} element - Element to edit classes of\r\n   * @param {...string} classes - Names of classes to remove\r\n   * @returns {Element} - `element` to allow for chaining\r\n   */\n\n\n  static removeClass(element, ...classes) {\n    for (let c = 0; c < classes.length; c++) classes[c] = classes[c].toString().split(\" \");\n\n    classes = classes.flat().filter(c => c);\n    element.classList.remove(...classes);\n    return element;\n  }\n  /**\r\n   * When only one argument is present: Toggle class value;\r\n   * i.e., if class exists then remove it and return false, if not, then add it and return true.\r\n   * When a second argument is present:\r\n   * If the second argument evaluates to true, add specified class value, and if it evaluates to false, remove it.\r\n   * @param {Element} element - Element to edit classes of\r\n   * @param {string} classname - Name of class to toggle\r\n   * @param {boolean} [indicator] - Optional indicator for if the class should be toggled\r\n   * @returns {Element} - `element` to allow for chaining\r\n   */\n\n\n  static toggleClass(element, classname, indicator) {\n    classname = classname.toString().split(\" \").filter(c => c);\n    if (typeof indicator !== \"undefined\") classname.forEach(c => element.classList.toggle(c, indicator));else classname.forEach(c => element.classList.toggle(c));\n    return element;\n  }\n  /**\r\n   * Checks if an element has a specific class\r\n   * @param {Element} element - Element to edit classes of\r\n   * @param {string} classname - Name of class to check\r\n   * @returns {boolean} - `true` if the element has the class, `false` otherwise.\r\n   */\n\n\n  static hasClass(element, classname) {\n    return classname.toString().split(\" \").filter(c => c).every(c => element.classList.contains(c));\n  }\n  /**\r\n   * Replaces one class with another\r\n   * @param {Element} element - Element to edit classes of\r\n   * @param {string} oldName - Name of class to replace\r\n   * @param {string} newName - New name for the class\r\n   * @returns {Element} - `element` to allow for chaining\r\n   */\n\n\n  static replaceClass(element, oldName, newName) {\n    element.classList.replace(oldName, newName);\n    return element;\n  }\n  /**\r\n   * Appends `thisNode` to `thatNode`\r\n   * @param {Node} thisNode - Node to be appended to another node\r\n   * @param {Node} thatNode - Node for `thisNode` to be appended to\r\n   * @returns {Node} - `thisNode` to allow for chaining\r\n   */\n\n\n  static appendTo(thisNode, thatNode) {\n    if (typeof thatNode == \"string\") thatNode = this.query(thatNode);\n    if (!thatNode) return null;\n    thatNode.append(thisNode);\n    return thisNode;\n  }\n  /**\r\n   * Prepends `thisNode` to `thatNode`\r\n   * @param {Node} thisNode - Node to be prepended to another node\r\n   * @param {Node} thatNode - Node for `thisNode` to be prepended to\r\n   * @returns {Node} - `thisNode` to allow for chaining\r\n   */\n\n\n  static prependTo(thisNode, thatNode) {\n    if (typeof thatNode == \"string\") thatNode = this.query(thatNode);\n    if (!thatNode) return null;\n    thatNode.prepend(thisNode);\n    return thisNode;\n  }\n  /**\r\n   * Insert after a specific element, similar to jQuery's `thisElement.insertAfter(otherElement)`.\r\n   * @param {Node} thisNode - The node to insert\r\n   * @param {Node} targetNode - Node to insert after in the tree\r\n   * @returns {Node} - `thisNode` to allow for chaining\r\n   */\n\n\n  static insertAfter(thisNode, targetNode) {\n    targetNode.parentNode.insertBefore(thisNode, targetNode.nextSibling);\n    return thisNode;\n  }\n  /**\r\n   * Insert after a specific element, similar to jQuery's `thisElement.after(newElement)`.\r\n   * @param {Node} thisNode - The node to insert\r\n   * @param {Node} newNode - Node to insert after in the tree\r\n   * @returns {Node} - `thisNode` to allow for chaining\r\n   */\n\n\n  static after(thisNode, newNode) {\n    thisNode.parentNode.insertBefore(newNode, thisNode.nextSibling);\n    return thisNode;\n  }\n  /**\r\n   * Gets the next sibling element that matches the selector.\r\n   * @param {Element} element - Element to get the next sibling of\r\n   * @param {string} [selector=\"\"] - Optional selector\r\n   * @returns {Element} - The sibling element\r\n   */\n\n\n  static next(element, selector = \"\") {\n    return selector ? element.querySelector(\"+ \" + selector) : element.nextElementSibling;\n  }\n  /**\r\n   * Gets all subsequent siblings.\r\n   * @param {Element} element - Element to get next siblings of\r\n   * @returns {NodeList} - The list of siblings\r\n   */\n\n\n  static nextAll(element) {\n    return element.querySelectorAll(\"~ *\");\n  }\n  /**\r\n   * Gets the subsequent siblings until an element matches the selector.\r\n   * @param {Element} element - Element to get the following siblings of\r\n   * @param {string} selector - Selector to stop at\r\n   * @returns {Array<Element>} - The list of siblings\r\n   */\n\n\n  static nextUntil(element, selector) {\n    const next = [];\n\n    while (element.nextElementSibling && !element.nextElementSibling.matches(selector)) next.push(element = element.nextElementSibling);\n\n    return next;\n  }\n  /**\r\n   * Gets the previous sibling element that matches the selector.\r\n   * @param {Element} element - Element to get the previous sibling of\r\n   * @param {string} [selector=\"\"] - Optional selector\r\n   * @returns {Element} - The sibling element\r\n   */\n\n\n  static previous(element, selector = \"\") {\n    const previous = element.previousElementSibling;\n    if (selector) return previous && previous.matches(selector) ? previous : null;\n    return previous;\n  }\n  /**\r\n   * Gets all preceeding siblings.\r\n   * @param {Element} element - Element to get preceeding siblings of\r\n   * @returns {NodeList} - The list of siblings\r\n   */\n\n\n  static previousAll(element) {\n    const previous = [];\n\n    while (element.previousElementSibling) previous.push(element = element.previousElementSibling);\n\n    return previous;\n  }\n  /**\r\n   * Gets the preceeding siblings until an element matches the selector.\r\n   * @param {Element} element - Element to get the preceeding siblings of\r\n   * @param {string} selector - Selector to stop at\r\n   * @returns {Array<Element>} - The list of siblings\r\n   */\n\n\n  static previousUntil(element, selector) {\n    const previous = [];\n\n    while (element.previousElementSibling && !element.previousElementSibling.matches(selector)) previous.push(element = element.previousElementSibling);\n\n    return previous;\n  }\n  /**\r\n   * Find which index in children a certain node is. Similar to jQuery's `$.index()`\r\n   * @param {HTMLElement} node - The node to find its index in parent\r\n   * @returns {number} Index of the node\r\n   */\n\n\n  static indexInParent(node) {\n    const children = node.parentNode.childNodes;\n    let num = 0;\n\n    for (let i = 0; i < children.length; i++) {\n      if (children[i] == node) return num;\n      if (children[i].nodeType == 1) num++;\n    }\n\n    return -1;\n  }\n  /** Shorthand for {@link module:DOMTools.indexInParent} */\n\n\n  static index(node) {\n    return this.indexInParent(node);\n  }\n  /**\r\n   * Gets the parent of the element if it matches the selector,\r\n   * otherwise returns null.\r\n   * @param {Element} element - Element to get parent of\r\n   * @param {string} [selector=\"\"] - Selector to match parent\r\n   * @returns {(Element|null)} - The sibling element or null\r\n   */\n\n\n  static parent(element, selector = \"\") {\n    return !selector || element.parentElement.matches(selector) ? element.parentElement : null;\n  }\n  /**\r\n   * Gets all children of Element that match the selector if provided.\r\n   * @param {Element} element - Element to get all children of\r\n   * @param {string} selector - Selector to match the children to\r\n   * @returns {Array<Element>} - The list of children\r\n   */\n\n\n  static findChild(element, selector) {\n    return element.querySelector(\":scope > \" + selector);\n  }\n  /**\r\n   * Gets all children of Element that match the selector if provided.\r\n   * @param {Element} element - Element to get all children of\r\n   * @param {string} selector - Selector to match the children to\r\n   * @returns {Array<Element>} - The list of children\r\n   */\n\n\n  static findChildren(element, selector) {\n    return element.querySelectorAll(\":scope > \" + selector);\n  }\n  /**\r\n   * Gets all ancestors of Element that match the selector if provided.\r\n   * @param {Element} element - Element to get all parents of\r\n   * @param {string} [selector=\"\"] - Selector to match the parents to\r\n   * @returns {Array<Element>} - The list of parents\r\n   */\n\n\n  static parents(element, selector = \"\") {\n    const parents = [];\n    if (selector) while (element.parentElement && element.parentElement.closest(selector)) parents.push(element = element.parentElement.closest(selector));else while (element.parentElement) parents.push(element = element.parentElement);\n    return parents;\n  }\n  /**\r\n   * Gets the ancestors until an element matches the selector.\r\n   * @param {Element} element - Element to get the ancestors of\r\n   * @param {string} selector - Selector to stop at\r\n   * @returns {Array<Element>} - The list of parents\r\n   */\n\n\n  static parentsUntil(element, selector) {\n    const parents = [];\n\n    while (element.parentElement && !element.parentElement.matches(selector)) parents.push(element = element.parentElement);\n\n    return parents;\n  }\n  /**\r\n   * Gets all siblings of the element that match the selector.\r\n   * @param {Element} element - Element to get all siblings of\r\n   * @param {string} [selector=\"*\"] - Selector to match the siblings to\r\n   * @returns {Array<Element>} - The list of siblings\r\n   */\n\n\n  static siblings(element, selector = \"*\") {\n    return Array.from(element.parentElement.children).filter(e => e != element && e.matches(selector));\n  }\n  /**\r\n   * Sets or gets css styles for a specific element. If `value` is provided\r\n   * then it sets the style and returns the element to allow for chaining,\r\n   * otherwise returns the style.  \r\n   * @param {Element} element - Element to set the CSS of\r\n   * @param {string} attribute - Attribute to get or set\r\n   * @param {string} [value] - Value to set for attribute\r\n   * @returns {Element|string} - When setting a value, element is returned for chaining, otherwise the value is returned.\r\n   */\n\n\n  static css(element, attribute, value) {\n    if (typeof value == \"undefined\") return global.getComputedStyle(element)[attribute];\n    element.style[attribute] = value;\n    return element;\n  }\n  /**\r\n   * Sets or gets the width for a specific element. If `value` is provided\r\n   * then it sets the width and returns the element to allow for chaining,\r\n   * otherwise returns the width.  \r\n   * @param {Element} element - Element to set the CSS of\r\n   * @param {string} [value] - Width to set\r\n   * @returns {Element|string} - When setting a value, element is returned for chaining, otherwise the value is returned.\r\n   */\n\n\n  static width(element, value) {\n    if (typeof value == \"undefined\") return parseInt(getComputedStyle(element).width);\n    element.style.width = value;\n    return element;\n  }\n  /**\r\n   * Sets or gets the height for a specific element. If `value` is provided\r\n   * then it sets the height and returns the element to allow for chaining,\r\n   * otherwise returns the height.  \r\n   * @param {Element} element - Element to set the CSS of\r\n   * @param {string} [value] - Height to set\r\n   * @returns {Element|string} - When setting a value, element is returned for chaining, otherwise the value is returned.\r\n   */\n\n\n  static height(element, value) {\n    if (typeof value == \"undefined\") return parseInt(getComputedStyle(element).height);\n    element.style.height = value;\n    return element;\n  }\n  /**\r\n   * Sets the inner text of an element if given a value, otherwise returns it.\r\n   * @param {Element} element - Element to set the text of\r\n   * @param {string} [text] - Content to set\r\n   * @returns {string} - Either the string set by this call or the current text content of the node.\r\n   */\n\n\n  static text(element, text) {\n    if (typeof text == \"undefined\") return element.textContent;\n    return element.textContent = text;\n  }\n  /**\r\n   * Returns the innerWidth of the element.\r\n   * @param {Element} element - Element to retrieve inner width of\r\n   * @return {number} - The inner width of the element.\r\n   */\n\n\n  static innerWidth(element) {\n    return element.clientWidth;\n  }\n  /**\r\n   * Returns the innerHeight of the element.\r\n   * @param {Element} element - Element to retrieve inner height of\r\n   * @return {number} - The inner height of the element.\r\n   */\n\n\n  static innerHeight(element) {\n    return element.clientHeight;\n  }\n  /**\r\n   * Returns the outerWidth of the element.\r\n   * @param {Element} element - Element to retrieve outer width of\r\n   * @return {number} - The outer width of the element.\r\n   */\n\n\n  static outerWidth(element) {\n    return element.offsetWidth;\n  }\n  /**\r\n   * Returns the outerHeight of the element.\r\n   * @param {Element} element - Element to retrieve outer height of\r\n   * @return {number} - The outer height of the element.\r\n   */\n\n\n  static outerHeight(element) {\n    return element.offsetHeight;\n  }\n  /**\r\n   * Gets the offset of the element in the page.\r\n   * @param {Element} element - Element to get offset of\r\n   * @return {Offset} - The offset of the element\r\n   */\n\n\n  static offset(element) {\n    return element.getBoundingClientRect();\n  }\n\n  static get listeners() {\n    return this._listeners || (this._listeners = {});\n  }\n  /**\r\n   * This is similar to jQuery's `on` function and can *hopefully* be used in the same way.\r\n   * \r\n   * Rather than attempt to explain, I'll show some example usages.\r\n   * \r\n   * The following will add a click listener (in the `myPlugin` namespace) to `element`.\r\n   * `DOMTools.on(element, \"click.myPlugin\", () => {console.log(\"clicked!\");});`\r\n   * \r\n   * The following will add a click listener (in the `myPlugin` namespace) to `element` that only fires when the target is a `.block` element.\r\n   * `DOMTools.on(element, \"click.myPlugin\", \".block\", () => {console.log(\"clicked!\");});`\r\n   * \r\n   * The following will add a click listener (without namespace) to `element`.\r\n   * `DOMTools.on(element, \"click\", () => {console.log(\"clicked!\");});`\r\n   * \r\n   * The following will add a click listener (without namespace) to `element` that only fires once.\r\n   * `const cancel = DOMTools.on(element, \"click\", () => {console.log(\"fired!\"); cancel();});`\r\n   * \r\n   * @param {Element} element - Element to add listener to\r\n   * @param {string} event - Event to listen to with option namespace (e.g. \"event.namespace\")\r\n   * @param {(string|callable)} delegate - Selector to run on element to listen to\r\n   * @param {callable} [callback] - Function to fire on event\r\n   * @returns {module:DOMTools~CancelListener} - A function that will undo the listener\r\n   */\n\n\n  static on(element, event, delegate, callback) {\n    const [type, namespace] = event.split(\".\");\n    const hasDelegate = delegate && callback;\n    if (!callback) callback = delegate;\n    const eventFunc = !hasDelegate ? callback : function (event) {\n      if (event.target.matches(delegate)) {\n        callback(event);\n      }\n    };\n    element.addEventListener(type, eventFunc);\n\n    const cancel = () => {\n      element.removeEventListener(type, eventFunc);\n    };\n\n    if (namespace) {\n      if (!this.listeners[namespace]) this.listeners[namespace] = [];\n\n      const newCancel = () => {\n        cancel();\n        this.listeners[namespace].splice(this.listeners[namespace].findIndex(l => l.event == type && l.element == element), 1);\n      };\n\n      this.listeners[namespace].push({\n        event: type,\n        element: element,\n        cancel: newCancel\n      });\n      return newCancel;\n    }\n\n    return cancel;\n  }\n  /**\r\n   * Functionality for this method matches {@link module:DOMTools.on} but automatically cancels itself\r\n   * and removes the listener upon the first firing of the desired event.\r\n   * \r\n   * @param {Element} element - Element to add listener to\r\n   * @param {string} event - Event to listen to with option namespace (e.g. \"event.namespace\")\r\n   * @param {(string|callable)} delegate - Selector to run on element to listen to\r\n   * @param {callable} [callback] - Function to fire on event\r\n   * @returns {module:DOMTools~CancelListener} - A function that will undo the listener\r\n   */\n\n\n  static once(element, event, delegate, callback) {\n    const [type, namespace] = event.split(\".\");\n    const hasDelegate = delegate && callback;\n    if (!callback) callback = delegate;\n    const eventFunc = !hasDelegate ? function (event) {\n      callback(event);\n      element.removeEventListener(type, eventFunc);\n    } : function (event) {\n      if (!event.target.matches(delegate)) return;\n      callback(event);\n      element.removeEventListener(type, eventFunc);\n    };\n    element.addEventListener(type, eventFunc);\n\n    const cancel = () => {\n      element.removeEventListener(type, eventFunc);\n    };\n\n    if (namespace) {\n      if (!this.listeners[namespace]) this.listeners[namespace] = [];\n\n      const newCancel = () => {\n        cancel();\n        this.listeners[namespace].splice(this.listeners[namespace].findIndex(l => l.event == type && l.element == element), 1);\n      };\n\n      this.listeners[namespace].push({\n        event: type,\n        element: element,\n        cancel: newCancel\n      });\n      return newCancel;\n    }\n\n    return cancel;\n  }\n\n  static __offAll(event, element) {\n    const [type, namespace] = event.split(\".\");\n\n    let matchFilter = listener => listener.event == type,\n        defaultFilter = _ => _;\n\n    if (element) matchFilter = l => l.event == type && l.element == element, defaultFilter = l => l.element == element;\n    const listeners = this.listeners[namespace] || [];\n    const list = type ? listeners.filter(matchFilter) : listeners.filter(defaultFilter);\n\n    for (let c = 0; c < list.length; c++) list[c].cancel();\n  }\n  /**\r\n   * This is similar to jQuery's `off` function and can *hopefully* be used in the same way.\r\n   * \r\n   * Rather than attempt to explain, I'll show some example usages.\r\n   * \r\n   * The following will remove a click listener called `onClick` (in the `myPlugin` namespace) from `element`.\r\n   * `DOMTools.off(element, \"click.myPlugin\", onClick);`\r\n   * \r\n   * The following will remove a click listener called `onClick` (in the `myPlugin` namespace) from `element` that only fired when the target is a `.block` element.\r\n   * `DOMTools.off(element, \"click.myPlugin\", \".block\", onClick);`\r\n   * \r\n   * The following will remove a click listener (without namespace) from `element`.\r\n   * `DOMTools.off(element, \"click\", onClick);`\r\n   * \r\n   * The following will remove all listeners in namespace `myPlugin` from `element`.\r\n   * `DOMTools.off(element, \".myPlugin\");`\r\n   * \r\n   * The following will remove all click listeners in namespace `myPlugin` from *all elements*.\r\n   * `DOMTools.off(\"click.myPlugin\");`\r\n   * \r\n   * The following will remove all listeners in namespace `myPlugin` from *all elements*.\r\n   * `DOMTools.off(\".myPlugin\");`\r\n   * \r\n   * @param {(Element|string)} element - Element to remove listener from\r\n   * @param {string} [event] - Event to listen to with option namespace (e.g. \"event.namespace\")\r\n   * @param {(string|callable)} [delegate] - Selector to run on element to listen to\r\n   * @param {callable} [callback] - Function to fire on event\r\n   * @returns {Element} - The original element to allow for chaining\r\n   */\n\n\n  static off(element, event, delegate, callback) {\n    if (typeof element == \"string\") return this.__offAll(element);\n    const [type, namespace] = event.split(\".\");\n    if (namespace) return this.__offAll(event, element);\n    const hasDelegate = delegate && callback;\n    if (!callback) callback = delegate;\n    const eventFunc = !hasDelegate ? callback : function (event) {\n      if (event.target.matches(delegate)) {\n        callback(event);\n      }\n    };\n    element.removeEventListener(type, eventFunc);\n    return element;\n  }\n  /**\r\n   * Adds a listener for when the node is added/removed from the document body.\r\n   * The listener is automatically removed upon firing.\r\n   * @param {HTMLElement} node - node to wait for\r\n   * @param {callable} callback - function to be performed on event\r\n   * @param {boolean} onMount - determines if it should fire on Mount or on Unmount\r\n   */\n\n\n  static onMountChange(node, callback, onMount = true) {\n    const wrappedCallback = () => {\n      this.observer.unsubscribe(wrappedCallback);\n      callback();\n    };\n\n    this.observer.subscribe(wrappedCallback, mutation => {\n      const nodes = Array.from(onMount ? mutation.addedNodes : mutation.removedNodes);\n      const directMatch = nodes.indexOf(node) > -1;\n      const parentMatch = nodes.some(parent => parent.contains(node));\n      return directMatch || parentMatch;\n    });\n    return node;\n  }\n  /** Shorthand for {@link module:DOMTools.onMountChange} with third parameter `true` */\n\n\n  static onMount(node, callback) {\n    return this.onMountChange(node, callback);\n  }\n  /** Shorthand for {@link module:DOMTools.onMountChange} with third parameter `false` */\n\n\n  static onUnmount(node, callback) {\n    return this.onMountChange(node, callback, false);\n  }\n  /** Alias for {@link module:DOMTools.onMount} */\n\n\n  static onAdded(node, callback) {\n    return this.onMount(node, callback);\n  }\n  /** Alias for {@link module:DOMTools.onUnmount} */\n\n\n  static onRemoved(node, callback) {\n    return this.onUnmount(node, callback, false);\n  }\n  /**\r\n   * Helper function which combines multiple elements into one parent element\r\n   * @param {Array<HTMLElement>} elements - array of elements to put into a single parent\r\n   */\n\n\n  static wrap(elements) {\n    const domWrapper = this.parseHTML(`<div class=\"dom-wrapper\"></div>`);\n\n    for (let e = 0; e < elements.length; e++) domWrapper.appendChild(elements[e]);\n\n    return domWrapper;\n  }\n  /**\r\n   * Resolves the node to an HTMLElement. This is mainly used by library modules.\r\n   * @param {(jQuery|Element)} node - node to resolve\r\n   */\n\n\n  static resolveElement(node) {\n    if (!(node instanceof jQuery) && !(node instanceof Element)) return undefined;\n    return node instanceof jQuery ? node[0] : node;\n  }\n\n}"],"mappings":"AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/modules/domtools.js\n"); + +/***/ }), + +/***/ "./src/modules/pluginModule.js": +/*!*************************************!*\ + !*** ./src/modules/pluginModule.js ***! + \*************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _contentManager__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./contentManager */ \"./src/modules/contentManager.js\");\n/* harmony import */ var _dataStore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./dataStore */ \"./src/modules/dataStore.js\");\n/* harmony import */ var _bdEvents__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./bdEvents */ \"./src/modules/bdEvents.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n\n\n\n\n\n\nclass PluginModule {\n get folder() {\n return _contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].pluginsFolder;\n }\n\n}\n\nPluginModule.prototype.loadPlugins = function () {\n this.loadPluginData();\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdpluginErrors\"].splice(0, 0, ..._contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].loadPlugins());\n const plugins = Object.keys(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"]);\n\n for (let i = 0; i < plugins.length; i++) {\n let plugin, name;\n\n try {\n plugin = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugins[i]].plugin;\n name = plugin.getName();\n if (plugin.load && typeof plugin.load == \"function\") plugin.load();\n } catch (err) {\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][name] = false;\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"Plugins\", name + \" could not be loaded.\", err);\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdpluginErrors\"].push({\n name: name,\n file: _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugins[i]].filename,\n message: \"load() could not be fired.\",\n error: {\n message: err.message,\n stack: err.stack\n }\n });\n continue;\n }\n\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][name]) _0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][name] = false;\n\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][name]) {\n try {\n plugin.start();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${plugin.getName()} v${plugin.getVersion()} has started.`);\n } catch (err) {\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][name] = false;\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"Plugins\", name + \" could not be started.\", err);\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdpluginErrors\"].push({\n name: name,\n file: _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugins[i]].filename,\n message: \"start() could not be fired.\",\n error: {\n message: err.message,\n stack: err.stack\n }\n });\n }\n }\n }\n\n this.savePluginData();\n\n __webpack_require__(/*! electron */ \"electron\").remote.getCurrentWebContents().on(\"did-navigate-in-page\", this.channelSwitch.bind(this)); // if (settingsCookie[\"fork-ps-5\"]) ContentManager.watchContent(\"plugin\");\n\n};\n\nPluginModule.prototype.startPlugin = function (plugin, reload = false) {\n try {\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.start();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"] && !reload) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.getName()} v${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.getVersion()} has started.`);\n } catch (err) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"] && !reload) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.getName()} v${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.getVersion()} could not be started.`, {\n type: \"error\"\n });\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][plugin] = false;\n this.savePluginData();\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"Plugins\", plugin + \" could not be started.\", err);\n }\n};\n\nPluginModule.prototype.stopPlugin = function (plugin, reload = false) {\n try {\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.stop();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"] && !reload) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.getName()} v${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.getVersion()} has stopped.`);\n } catch (err) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"] && !reload) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.getName()} v${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.getVersion()} could not be stopped.`, {\n type: \"error\"\n });\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"Plugins\", _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.getName() + \" could not be stopped.\", err);\n }\n};\n\nPluginModule.prototype.enablePlugin = function (plugin, reload = false) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][plugin]) return;\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][plugin] = true;\n this.savePluginData();\n this.startPlugin(plugin, reload);\n};\n\nPluginModule.prototype.enable = function (plugin, reload = false) {\n return this.enablePlugin(plugin, reload);\n};\n\nPluginModule.prototype.disablePlugin = function (plugin, reload = false) {\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][plugin]) return;\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][plugin] = false;\n this.savePluginData();\n this.stopPlugin(plugin, reload);\n};\n\nPluginModule.prototype.disable = function (plugin, reload = false) {\n return this.disablePlugin(plugin, reload);\n};\n\nPluginModule.prototype.togglePlugin = function (plugin) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][plugin]) this.disablePlugin(plugin);else this.enablePlugin(plugin);\n};\n\nPluginModule.prototype.toggle = function (plugin, reload = false) {\n return this.togglePlugin(plugin, reload);\n};\n\nPluginModule.prototype.loadPlugin = function (filename) {\n const error = _contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].loadContent(filename, \"plugin\");\n\n if (error) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-1\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showContentErrors({\n plugins: [error]\n });\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${filename} could not be loaded.`, {\n type: \"error\"\n });\n return _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"ContentManager\", `${filename} could not be loaded.`, error);\n }\n\n const plugin = Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"]).find(p => p.filename == filename).plugin;\n\n try {\n if (plugin.load && typeof plugin.load == \"function\") plugin.load();\n } catch (err) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-1\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showContentErrors({\n plugins: [err]\n });\n }\n\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].log(\"ContentManager\", `${plugin.getName()} v${plugin.getVersion()} was loaded.`);\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${plugin.getName()} v${plugin.getVersion()} was loaded.`, {\n type: \"success\"\n });\n _bdEvents__WEBPACK_IMPORTED_MODULE_3__[\"default\"].dispatch(\"plugin-loaded\", plugin.getName());\n};\n\nPluginModule.prototype.unloadPlugin = function (filenameOrName) {\n const bdplugin = Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"]).find(p => p.filename == filenameOrName) || _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][filenameOrName];\n if (!bdplugin) return;\n const plugin = bdplugin.plugin.getName();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][plugin]) this.disablePlugin(plugin, true);\n const error = _contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].unloadContent(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].filename, \"plugin\");\n delete _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin];\n\n if (error) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-1\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showContentErrors({\n plugins: [error]\n });\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${plugin} could not be unloaded. It may have not been loaded yet.`, {\n type: \"error\"\n });\n return _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"ContentManager\", `${plugin} could not be unloaded. It may have not been loaded yet.`, error);\n }\n\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].log(\"ContentManager\", `${plugin} was unloaded.`);\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${plugin} was unloaded.`, {\n type: \"success\"\n });\n _bdEvents__WEBPACK_IMPORTED_MODULE_3__[\"default\"].dispatch(\"plugin-unloaded\", plugin);\n};\n\nPluginModule.prototype.delete = function (filenameOrName) {\n const bdplugin = Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"]).find(p => p.filename == filenameOrName) || _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][filenameOrName];\n if (!bdplugin) return;\n this.unloadPlugin(bdplugin.filename);\n\n const fullPath = __webpack_require__(/*! path */ \"path\").resolve(_contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].pluginsFolder, bdplugin.filename);\n\n __webpack_require__(/*! fs */ \"fs\").unlinkSync(fullPath);\n};\n\nPluginModule.prototype.reloadPlugin = function (filenameOrName) {\n const bdplugin = Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"]).find(p => p.filename == filenameOrName) || _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][filenameOrName];\n if (!bdplugin) return this.loadPlugin(filenameOrName);\n const plugin = bdplugin.plugin.getName();\n const enabled = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][plugin];\n if (enabled) this.stopPlugin(plugin, true);\n const error = _contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reloadContent(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].filename, \"plugin\");\n\n if (error) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-1\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showContentErrors({\n plugins: [error]\n });\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${plugin} could not be reloaded.`, {\n type: \"error\"\n });\n return _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"ContentManager\", `${plugin} could not be reloaded.`, error);\n }\n\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.load && typeof _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.load == \"function\") _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.load();\n if (enabled) this.startPlugin(plugin, true);\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].log(\"ContentManager\", `${plugin} v${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.getVersion()} was reloaded.`);\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${plugin} v${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugin].plugin.getVersion()} was reloaded.`, {\n type: \"success\"\n });\n _bdEvents__WEBPACK_IMPORTED_MODULE_3__[\"default\"].dispatch(\"plugin-reloaded\", plugin);\n};\n\nPluginModule.prototype.reload = function (name) {\n return this.reloadPlugin(name);\n};\n\nPluginModule.prototype.edit = function (filenameOrName) {\n console.log(\"Edit \" + filenameOrName);\n const bdplugin = Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"]).find(p => p.filename == filenameOrName) || _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][filenameOrName];\n if (!bdplugin) return;\n\n const fullPath = __webpack_require__(/*! path */ \"path\").resolve(_contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].pluginsFolder, bdplugin.filename);\n\n console.log(\"Edit \" + fullPath);\n\n __webpack_require__(/*! electron */ \"electron\").shell.openItem(`${fullPath}`);\n};\n\nPluginModule.prototype.updatePluginList = function () {\n const results = _contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].loadNewContent(\"plugin\");\n\n for (const filename of results.added) this.loadPlugin(filename);\n\n for (const name of results.removed) this.unloadPlugin(name);\n};\n\nPluginModule.prototype.loadPluginData = function () {\n const saved = _dataStore__WEBPACK_IMPORTED_MODULE_2__[\"default\"].getSettingGroup(\"plugins\");\n\n if (saved) {\n Object.assign(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"], saved);\n }\n};\n\nPluginModule.prototype.savePluginData = function () {\n _dataStore__WEBPACK_IMPORTED_MODULE_2__[\"default\"].setSettingGroup(\"plugins\", _0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"]);\n};\n\nPluginModule.prototype.newMessage = function () {\n const plugins = Object.keys(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"]);\n\n for (let i = 0; i < plugins.length; i++) {\n const plugin = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugins[i]].plugin;\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][plugin.getName()]) continue;\n\n if (typeof plugin.onMessage === \"function\") {\n try {\n plugin.onMessage();\n } catch (err) {\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"Plugins\", \"Unable to fire onMessage for \" + plugin.getName() + \".\", err);\n }\n }\n }\n};\n\nPluginModule.prototype.channelSwitch = function () {\n const plugins = Object.keys(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"]);\n\n for (let i = 0; i < plugins.length; i++) {\n const plugin = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugins[i]].plugin;\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][plugin.getName()]) continue;\n\n if (typeof plugin.onSwitch === \"function\") {\n try {\n plugin.onSwitch();\n } catch (err) {\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"Plugins\", \"Unable to fire onSwitch for \" + plugin.getName() + \".\", err);\n }\n }\n }\n};\n\nPluginModule.prototype.rawObserver = function (e) {\n const plugins = Object.keys(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"]);\n\n for (let i = 0; i < plugins.length; i++) {\n const plugin = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"][plugins[i]].plugin;\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"pluginCookie\"][plugin.getName()]) continue;\n\n if (typeof plugin.observer === \"function\") {\n try {\n plugin.observer(e);\n } catch (err) {\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"Plugins\", \"Unable to fire observer for \" + plugin.getName() + \".\", err);\n }\n }\n }\n};\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (new PluginModule());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/modules/pluginModule.js.js","sources":["webpack://BetterDiscord/./src/modules/pluginModule.js?aa7f"],"sourcesContent":["import { bdpluginErrors, pluginCookie, settingsCookie, bdplugins } from \"../0globals\";\nimport ContentManager from \"./contentManager\";\nimport DataStore from \"./dataStore\";\nimport BDEvents from \"./bdEvents\";\nimport Utils from \"./utils\";\n\nclass PluginModule {\n  get folder() {\n    return ContentManager.pluginsFolder;\n  }\n\n}\n\nPluginModule.prototype.loadPlugins = function () {\n  this.loadPluginData();\n  bdpluginErrors.splice(0, 0, ...ContentManager.loadPlugins());\n  const plugins = Object.keys(bdplugins);\n\n  for (let i = 0; i < plugins.length; i++) {\n    let plugin, name;\n\n    try {\n      plugin = bdplugins[plugins[i]].plugin;\n      name = plugin.getName();\n      if (plugin.load && typeof plugin.load == \"function\") plugin.load();\n    } catch (err) {\n      pluginCookie[name] = false;\n      Utils.err(\"Plugins\", name + \" could not be loaded.\", err);\n      bdpluginErrors.push({\n        name: name,\n        file: bdplugins[plugins[i]].filename,\n        message: \"load() could not be fired.\",\n        error: {\n          message: err.message,\n          stack: err.stack\n        }\n      });\n      continue;\n    }\n\n    if (!pluginCookie[name]) pluginCookie[name] = false;\n\n    if (pluginCookie[name]) {\n      try {\n        plugin.start();\n        if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${plugin.getName()} v${plugin.getVersion()} has started.`);\n      } catch (err) {\n        pluginCookie[name] = false;\n        Utils.err(\"Plugins\", name + \" could not be started.\", err);\n        bdpluginErrors.push({\n          name: name,\n          file: bdplugins[plugins[i]].filename,\n          message: \"start() could not be fired.\",\n          error: {\n            message: err.message,\n            stack: err.stack\n          }\n        });\n      }\n    }\n  }\n\n  this.savePluginData();\n\n  require(\"electron\").remote.getCurrentWebContents().on(\"did-navigate-in-page\", this.channelSwitch.bind(this)); // if (settingsCookie[\"fork-ps-5\"]) ContentManager.watchContent(\"plugin\");\n\n};\n\nPluginModule.prototype.startPlugin = function (plugin, reload = false) {\n  try {\n    bdplugins[plugin].plugin.start();\n    if (settingsCookie[\"fork-ps-2\"] && !reload) Utils.showToast(`${bdplugins[plugin].plugin.getName()} v${bdplugins[plugin].plugin.getVersion()} has started.`);\n  } catch (err) {\n    if (settingsCookie[\"fork-ps-2\"] && !reload) Utils.showToast(`${bdplugins[plugin].plugin.getName()} v${bdplugins[plugin].plugin.getVersion()} could not be started.`, {\n      type: \"error\"\n    });\n    pluginCookie[plugin] = false;\n    this.savePluginData();\n    Utils.err(\"Plugins\", plugin + \" could not be started.\", err);\n  }\n};\n\nPluginModule.prototype.stopPlugin = function (plugin, reload = false) {\n  try {\n    bdplugins[plugin].plugin.stop();\n    if (settingsCookie[\"fork-ps-2\"] && !reload) Utils.showToast(`${bdplugins[plugin].plugin.getName()} v${bdplugins[plugin].plugin.getVersion()} has stopped.`);\n  } catch (err) {\n    if (settingsCookie[\"fork-ps-2\"] && !reload) Utils.showToast(`${bdplugins[plugin].plugin.getName()} v${bdplugins[plugin].plugin.getVersion()} could not be stopped.`, {\n      type: \"error\"\n    });\n    Utils.err(\"Plugins\", bdplugins[plugin].plugin.getName() + \" could not be stopped.\", err);\n  }\n};\n\nPluginModule.prototype.enablePlugin = function (plugin, reload = false) {\n  if (pluginCookie[plugin]) return;\n  pluginCookie[plugin] = true;\n  this.savePluginData();\n  this.startPlugin(plugin, reload);\n};\n\nPluginModule.prototype.enable = function (plugin, reload = false) {\n  return this.enablePlugin(plugin, reload);\n};\n\nPluginModule.prototype.disablePlugin = function (plugin, reload = false) {\n  if (!pluginCookie[plugin]) return;\n  pluginCookie[plugin] = false;\n  this.savePluginData();\n  this.stopPlugin(plugin, reload);\n};\n\nPluginModule.prototype.disable = function (plugin, reload = false) {\n  return this.disablePlugin(plugin, reload);\n};\n\nPluginModule.prototype.togglePlugin = function (plugin) {\n  if (pluginCookie[plugin]) this.disablePlugin(plugin);else this.enablePlugin(plugin);\n};\n\nPluginModule.prototype.toggle = function (plugin, reload = false) {\n  return this.togglePlugin(plugin, reload);\n};\n\nPluginModule.prototype.loadPlugin = function (filename) {\n  const error = ContentManager.loadContent(filename, \"plugin\");\n\n  if (error) {\n    if (settingsCookie[\"fork-ps-1\"]) Utils.showContentErrors({\n      plugins: [error]\n    });\n    if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${filename} could not be loaded.`, {\n      type: \"error\"\n    });\n    return Utils.err(\"ContentManager\", `${filename} could not be loaded.`, error);\n  }\n\n  const plugin = Object.values(bdplugins).find(p => p.filename == filename).plugin;\n\n  try {\n    if (plugin.load && typeof plugin.load == \"function\") plugin.load();\n  } catch (err) {\n    if (settingsCookie[\"fork-ps-1\"]) Utils.showContentErrors({\n      plugins: [err]\n    });\n  }\n\n  Utils.log(\"ContentManager\", `${plugin.getName()} v${plugin.getVersion()} was loaded.`);\n  if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${plugin.getName()} v${plugin.getVersion()} was loaded.`, {\n    type: \"success\"\n  });\n  BDEvents.dispatch(\"plugin-loaded\", plugin.getName());\n};\n\nPluginModule.prototype.unloadPlugin = function (filenameOrName) {\n  const bdplugin = Object.values(bdplugins).find(p => p.filename == filenameOrName) || bdplugins[filenameOrName];\n  if (!bdplugin) return;\n  const plugin = bdplugin.plugin.getName();\n  if (pluginCookie[plugin]) this.disablePlugin(plugin, true);\n  const error = ContentManager.unloadContent(bdplugins[plugin].filename, \"plugin\");\n  delete bdplugins[plugin];\n\n  if (error) {\n    if (settingsCookie[\"fork-ps-1\"]) Utils.showContentErrors({\n      plugins: [error]\n    });\n    if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${plugin} could not be unloaded. It may have not been loaded yet.`, {\n      type: \"error\"\n    });\n    return Utils.err(\"ContentManager\", `${plugin} could not be unloaded. It may have not been loaded yet.`, error);\n  }\n\n  Utils.log(\"ContentManager\", `${plugin} was unloaded.`);\n  if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${plugin} was unloaded.`, {\n    type: \"success\"\n  });\n  BDEvents.dispatch(\"plugin-unloaded\", plugin);\n};\n\nPluginModule.prototype.delete = function (filenameOrName) {\n  const bdplugin = Object.values(bdplugins).find(p => p.filename == filenameOrName) || bdplugins[filenameOrName];\n  if (!bdplugin) return;\n  this.unloadPlugin(bdplugin.filename);\n\n  const fullPath = require(\"path\").resolve(ContentManager.pluginsFolder, bdplugin.filename);\n\n  require(\"fs\").unlinkSync(fullPath);\n};\n\nPluginModule.prototype.reloadPlugin = function (filenameOrName) {\n  const bdplugin = Object.values(bdplugins).find(p => p.filename == filenameOrName) || bdplugins[filenameOrName];\n  if (!bdplugin) return this.loadPlugin(filenameOrName);\n  const plugin = bdplugin.plugin.getName();\n  const enabled = pluginCookie[plugin];\n  if (enabled) this.stopPlugin(plugin, true);\n  const error = ContentManager.reloadContent(bdplugins[plugin].filename, \"plugin\");\n\n  if (error) {\n    if (settingsCookie[\"fork-ps-1\"]) Utils.showContentErrors({\n      plugins: [error]\n    });\n    if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${plugin} could not be reloaded.`, {\n      type: \"error\"\n    });\n    return Utils.err(\"ContentManager\", `${plugin} could not be reloaded.`, error);\n  }\n\n  if (bdplugins[plugin].plugin.load && typeof bdplugins[plugin].plugin.load == \"function\") bdplugins[plugin].plugin.load();\n  if (enabled) this.startPlugin(plugin, true);\n  Utils.log(\"ContentManager\", `${plugin} v${bdplugins[plugin].plugin.getVersion()} was reloaded.`);\n  if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${plugin} v${bdplugins[plugin].plugin.getVersion()} was reloaded.`, {\n    type: \"success\"\n  });\n  BDEvents.dispatch(\"plugin-reloaded\", plugin);\n};\n\nPluginModule.prototype.reload = function (name) {\n  return this.reloadPlugin(name);\n};\n\nPluginModule.prototype.edit = function (filenameOrName) {\n  console.log(\"Edit \" + filenameOrName);\n  const bdplugin = Object.values(bdplugins).find(p => p.filename == filenameOrName) || bdplugins[filenameOrName];\n  if (!bdplugin) return;\n\n  const fullPath = require(\"path\").resolve(ContentManager.pluginsFolder, bdplugin.filename);\n\n  console.log(\"Edit \" + fullPath);\n\n  require(\"electron\").shell.openItem(`${fullPath}`);\n};\n\nPluginModule.prototype.updatePluginList = function () {\n  const results = ContentManager.loadNewContent(\"plugin\");\n\n  for (const filename of results.added) this.loadPlugin(filename);\n\n  for (const name of results.removed) this.unloadPlugin(name);\n};\n\nPluginModule.prototype.loadPluginData = function () {\n  const saved = DataStore.getSettingGroup(\"plugins\");\n\n  if (saved) {\n    Object.assign(pluginCookie, saved);\n  }\n};\n\nPluginModule.prototype.savePluginData = function () {\n  DataStore.setSettingGroup(\"plugins\", pluginCookie);\n};\n\nPluginModule.prototype.newMessage = function () {\n  const plugins = Object.keys(bdplugins);\n\n  for (let i = 0; i < plugins.length; i++) {\n    const plugin = bdplugins[plugins[i]].plugin;\n    if (!pluginCookie[plugin.getName()]) continue;\n\n    if (typeof plugin.onMessage === \"function\") {\n      try {\n        plugin.onMessage();\n      } catch (err) {\n        Utils.err(\"Plugins\", \"Unable to fire onMessage for \" + plugin.getName() + \".\", err);\n      }\n    }\n  }\n};\n\nPluginModule.prototype.channelSwitch = function () {\n  const plugins = Object.keys(bdplugins);\n\n  for (let i = 0; i < plugins.length; i++) {\n    const plugin = bdplugins[plugins[i]].plugin;\n    if (!pluginCookie[plugin.getName()]) continue;\n\n    if (typeof plugin.onSwitch === \"function\") {\n      try {\n        plugin.onSwitch();\n      } catch (err) {\n        Utils.err(\"Plugins\", \"Unable to fire onSwitch for \" + plugin.getName() + \".\", err);\n      }\n    }\n  }\n};\n\nPluginModule.prototype.rawObserver = function (e) {\n  const plugins = Object.keys(bdplugins);\n\n  for (let i = 0; i < plugins.length; i++) {\n    const plugin = bdplugins[plugins[i]].plugin;\n    if (!pluginCookie[plugin.getName()]) continue;\n\n    if (typeof plugin.observer === \"function\") {\n      try {\n        plugin.observer(e);\n      } catch (err) {\n        Utils.err(\"Plugins\", \"Unable to fire observer for \" + plugin.getName() + \".\", err);\n      }\n    }\n  }\n};\n\nexport default new PluginModule();"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/modules/pluginModule.js\n"); + +/***/ }), + +/***/ "./src/modules/publicServers.js": +/*!**************************************!*\ + !*** ./src/modules/publicServers.js ***! + \**************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _v2__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _webpackModules__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./webpackModules */ \"./src/modules/webpackModules.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _domtools__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./domtools */ \"./src/modules/domtools.js\");\n/* harmony import */ var _ui_publicservers_publicServers__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../ui/publicservers/publicServers */ \"./src/ui/publicservers/publicServers.js\");\n/* harmony import */ var _ui_publicservers_layer__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../ui/publicservers/layer */ \"./src/ui/publicservers/layer.js\");\n\n\n\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class V2_PublicServers {\n constructor() {\n this._appendButton = this._appendButton.bind(this);\n }\n\n get component() {\n return _v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(_ui_publicservers_layer__WEBPACK_IMPORTED_MODULE_6__[\"default\"], {\n rootId: \"pubslayerroot\",\n id: \"pubslayer\"\n }, _v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(_ui_publicservers_publicServers__WEBPACK_IMPORTED_MODULE_5__[\"default\"], {\n rootId: \"pubslayerroot\"\n }));\n }\n\n get root() {\n const _root = document.getElementById(\"pubslayerroot\");\n\n if (!_root) {\n if (!this.injectRoot()) return null;\n return this.root;\n }\n\n return _root;\n }\n\n injectRoot() {\n let [classNameLayers] = [BDModules.get(e => e.layers && e.layer)[0].layers.split(\" \")[0]];\n const layers = _domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].query(\".layers, .\" + classNameLayers);\n if (!layers) return false;\n layers.append(_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].createElement(\"
\"));\n return true;\n }\n\n render() {\n const root = this.root;\n\n if (!root) {\n console.log(\"FAILED TO LOCATE ROOT: .layers\");\n return;\n }\n\n _v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reactDom.render(this.component, root);\n }\n\n get button() {\n const btn = _domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].createElement(`
`);\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-gs-1\"]) btn.style.display = \"none\";\n const label = _domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].createElement(`
public
`);\n label.addEventListener(\"click\", () => {\n this.render();\n });\n btn.append(label);\n return btn;\n }\n\n _appendButton() {\n let [classNameScroller] = [BDModules.get(e => e.scroller && e.scrollbarWidth)[0].scroller];\n if (_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].query(\"#bd-pub-li\")) return;\n const wrapper = _v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].guildClasses.wrapper.split(\" \")[0];\n const guilds = _domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].query(`.${wrapper} .${classNameScroller} >:first-child`);\n _domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].after(guilds, this.button);\n }\n\n addButton() {\n if (this.guildPatch) return;\n const GuildList = _webpackModules__WEBPACK_IMPORTED_MODULE_2__[\"default\"].find(m => m.default && m.default.displayName == \"NavigableGuilds\");\n const GuildListOld = _webpackModules__WEBPACK_IMPORTED_MODULE_2__[\"default\"].findByDisplayName(\"Guilds\");\n if (!GuildList && !GuildListOld) _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].warn(\"PublicServer\", \"Can't find GuildList component\");\n this.guildPatch = _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].monkeyPatch(GuildList ? GuildList : GuildListOld.prototype, GuildList ? \"default\" : \"render\", {\n after: this._appendButton\n });\n\n this._appendButton();\n }\n\n removeButton() {\n this.guildPatch();\n delete this.guildPatch;\n _domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].query(\"#bd-pub-li\").remove();\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbW9kdWxlcy9wdWJsaWNTZXJ2ZXJzLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQmV0dGVyRGlzY29yZC8uL3NyYy9tb2R1bGVzL3B1YmxpY1NlcnZlcnMuanM/ZTBlOSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzZXR0aW5nc0Nvb2tpZSB9IGZyb20gXCIuLi8wZ2xvYmFsc1wiO1xuaW1wb3J0IEJEVjIgZnJvbSBcIi4vdjJcIjtcbmltcG9ydCB3ZWJwYWNrTW9kdWxlcyBmcm9tIFwiLi93ZWJwYWNrTW9kdWxlc1wiO1xuaW1wb3J0IFV0aWxzIGZyb20gXCIuL3V0aWxzXCI7XG5pbXBvcnQgRE9NIGZyb20gXCIuL2RvbXRvb2xzXCI7XG5pbXBvcnQgVjJDX1B1YmxpY1NlcnZlcnMgZnJvbSBcIi4uL3VpL3B1YmxpY3NlcnZlcnMvcHVibGljU2VydmVyc1wiO1xuaW1wb3J0IExheWVyIGZyb20gXCIuLi91aS9wdWJsaWNzZXJ2ZXJzL2xheWVyXCI7XG5leHBvcnQgZGVmYXVsdCBuZXcgY2xhc3MgVjJfUHVibGljU2VydmVycyB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMuX2FwcGVuZEJ1dHRvbiA9IHRoaXMuX2FwcGVuZEJ1dHRvbi5iaW5kKHRoaXMpO1xuICB9XG5cbiAgZ2V0IGNvbXBvbmVudCgpIHtcbiAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KExheWVyLCB7XG4gICAgICByb290SWQ6IFwicHVic2xheWVycm9vdFwiLFxuICAgICAgaWQ6IFwicHVic2xheWVyXCJcbiAgICB9LCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoVjJDX1B1YmxpY1NlcnZlcnMsIHtcbiAgICAgIHJvb3RJZDogXCJwdWJzbGF5ZXJyb290XCJcbiAgICB9KSk7XG4gIH1cblxuICBnZXQgcm9vdCgpIHtcbiAgICBjb25zdCBfcm9vdCA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKFwicHVic2xheWVycm9vdFwiKTtcblxuICAgIGlmICghX3Jvb3QpIHtcbiAgICAgIGlmICghdGhpcy5pbmplY3RSb290KCkpIHJldHVybiBudWxsO1xuICAgICAgcmV0dXJuIHRoaXMucm9vdDtcbiAgICB9XG5cbiAgICByZXR1cm4gX3Jvb3Q7XG4gIH1cblxuICBpbmplY3RSb290KCkge1xuICAgIGxldCBbY2xhc3NOYW1lTGF5ZXJzXSA9IFtCRE1vZHVsZXMuZ2V0KGUgPT4gZS5sYXllcnMgJiYgZS5sYXllcilbMF0ubGF5ZXJzLnNwbGl0KFwiIFwiKVswXV07XG4gICAgY29uc3QgbGF5ZXJzID0gRE9NLnF1ZXJ5KFwiLmxheWVycywgLlwiICsgY2xhc3NOYW1lTGF5ZXJzKTtcbiAgICBpZiAoIWxheWVycykgcmV0dXJuIGZhbHNlO1xuICAgIGxheWVycy5hcHBlbmQoRE9NLmNyZWF0ZUVsZW1lbnQoXCI8ZGl2IGlkPSdwdWJzbGF5ZXJyb290Jz5cIikpO1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHJvb3QgPSB0aGlzLnJvb3Q7XG5cbiAgICBpZiAoIXJvb3QpIHtcbiAgICAgIGNvbnNvbGUubG9nKFwiRkFJTEVEIFRPIExPQ0FURSBST09UOiAubGF5ZXJzXCIpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIEJEVjIucmVhY3REb20ucmVuZGVyKHRoaXMuY29tcG9uZW50LCByb290KTtcbiAgfVxuXG4gIGdldCBidXR0b24oKSB7XG4gICAgY29uc3QgYnRuID0gRE9NLmNyZWF0ZUVsZW1lbnQoYDxkaXYgaWQ9XCJiZC1wdWItbGlcIiBjbGFzcz1cIiR7QkRWMi5ndWlsZENsYXNzZXMubGlzdEl0ZW19XCI+YCk7XG4gICAgaWYgKCFzZXR0aW5nc0Nvb2tpZVtcImJkYS1ncy0xXCJdKSBidG4uc3R5bGUuZGlzcGxheSA9IFwibm9uZVwiO1xuICAgIGNvbnN0IGxhYmVsID0gRE9NLmNyZWF0ZUVsZW1lbnQoYDxkaXYgaWQ9XCJiZC1wdWItYnV0dG9uXCIgY2xhc3M9XCIke1wid3JhcHBlci0yNWVWSW4gXCIgKyBCRFYyLmd1aWxkQ2xhc3Nlcy5jaXJjbGVCdXR0b25NYXNrfVwiPnB1YmxpYzwvZGl2PmApO1xuICAgIGxhYmVsLmFkZEV2ZW50TGlzdGVuZXIoXCJjbGlja1wiLCAoKSA9PiB7XG4gICAgICB0aGlzLnJlbmRlcigpO1xuICAgIH0pO1xuICAgIGJ0bi5hcHBlbmQobGFiZWwpO1xuICAgIHJldHVybiBidG47XG4gIH1cblxuICBfYXBwZW5kQnV0dG9uKCkge1xuICAgIGxldCBbY2xhc3NOYW1lU2Nyb2xsZXJdID0gW0JETW9kdWxlcy5nZXQoZSA9PiBlLnNjcm9sbGVyICYmIGUuc2Nyb2xsYmFyV2lkdGgpWzBdLnNjcm9sbGVyXTtcbiAgICBpZiAoRE9NLnF1ZXJ5KFwiI2JkLXB1Yi1saVwiKSkgcmV0dXJuO1xuICAgIGNvbnN0IHdyYXBwZXIgPSBCRFYyLmd1aWxkQ2xhc3Nlcy53cmFwcGVyLnNwbGl0KFwiIFwiKVswXTtcbiAgICBjb25zdCBndWlsZHMgPSBET00ucXVlcnkoYC4ke3dyYXBwZXJ9IC4ke2NsYXNzTmFtZVNjcm9sbGVyfSA+OmZpcnN0LWNoaWxkYCk7XG4gICAgRE9NLmFmdGVyKGd1aWxkcywgdGhpcy5idXR0b24pO1xuICB9XG5cbiAgYWRkQnV0dG9uKCkge1xuICAgIGlmICh0aGlzLmd1aWxkUGF0Y2gpIHJldHVybjtcbiAgICBjb25zdCBHdWlsZExpc3QgPSB3ZWJwYWNrTW9kdWxlcy5maW5kKG0gPT4gbS5kZWZhdWx0ICYmIG0uZGVmYXVsdC5kaXNwbGF5TmFtZSA9PSBcIk5hdmlnYWJsZUd1aWxkc1wiKTtcbiAgICBjb25zdCBHdWlsZExpc3RPbGQgPSB3ZWJwYWNrTW9kdWxlcy5maW5kQnlEaXNwbGF5TmFtZShcIkd1aWxkc1wiKTtcbiAgICBpZiAoIUd1aWxkTGlzdCAmJiAhR3VpbGRMaXN0T2xkKSBVdGlscy53YXJuKFwiUHVibGljU2VydmVyXCIsIFwiQ2FuJ3QgZmluZCBHdWlsZExpc3QgY29tcG9uZW50XCIpO1xuICAgIHRoaXMuZ3VpbGRQYXRjaCA9IFV0aWxzLm1vbmtleVBhdGNoKEd1aWxkTGlzdCA/IEd1aWxkTGlzdCA6IEd1aWxkTGlzdE9sZC5wcm90b3R5cGUsIEd1aWxkTGlzdCA/IFwiZGVmYXVsdFwiIDogXCJyZW5kZXJcIiwge1xuICAgICAgYWZ0ZXI6IHRoaXMuX2FwcGVuZEJ1dHRvblxuICAgIH0pO1xuXG4gICAgdGhpcy5fYXBwZW5kQnV0dG9uKCk7XG4gIH1cblxuICByZW1vdmVCdXR0b24oKSB7XG4gICAgdGhpcy5ndWlsZFBhdGNoKCk7XG4gICAgZGVsZXRlIHRoaXMuZ3VpbGRQYXRjaDtcbiAgICBET00ucXVlcnkoXCIjYmQtcHViLWxpXCIpLnJlbW92ZSgpO1xuICB9XG5cbn0oKTsiXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/modules/publicServers.js\n"); + +/***/ }), + +/***/ "./src/modules/reactDevTools.js": +/*!**************************************!*\ + !*** ./src/modules/reactDevTools.js ***! + \**************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n\n\n\nconst electron = __webpack_require__(/*! electron */ \"electron\");\n\nconst fs = __webpack_require__(/*! fs */ \"fs\");\n\nconst path = __webpack_require__(/*! path */ \"path\");\n\nconst BrowserWindow = electron.remote.BrowserWindow;\nconst webContents = electron.remote.getCurrentWebContents();\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class reactDevTools {\n constructor() {\n let extensionPath = \"\";\n if (process.platform === \"win32\") extensionPath = path.resolve(process.env.LOCALAPPDATA, \"Google/Chrome/User Data\");else if (process.platform === \"linux\") extensionPath = path.resolve(process.env.HOME, \".config/google-chrome\");else if (process.platform === \"darwin\") extensionPath = path.resolve(process.env.HOME, \"Library/Application Support/Google/Chrome\");else extensionPath = path.resolve(process.env.HOME, \".config/chromium\");\n extensionPath += \"/Default/Extensions/fmkadmapgofadopljbjfkapdkoienihi/\";\n\n if (fs.existsSync(extensionPath)) {\n const versions = fs.readdirSync(extensionPath);\n extensionPath = path.resolve(extensionPath, versions[versions.length - 1]);\n }\n\n this.extensionPath = extensionPath;\n this.isExtensionInstalled = fs.existsSync(extensionPath);\n this.listener = this.listener.bind(this);\n _0globals__WEBPACK_IMPORTED_MODULE_1__[\"settings\"][\"React DevTools\"].hidden = !this.isExtensionInstalled;\n }\n\n listener() {\n if (!this.isExtensionInstalled) return;\n BrowserWindow.removeDevToolsExtension(\"React Developer Tools\");\n const didInstall = BrowserWindow.addDevToolsExtension(this.extensionPath);\n if (didInstall) _utils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].log(\"React DevTools\", \"Successfully installed react devtools.\");else _utils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].err(\"React DevTools\", \"Couldn't find react devtools in chrome extensions!\");\n }\n\n start() {\n setImmediate(() => webContents.on(\"devtools-opened\", this.listener));\n if (webContents.isDevToolsOpened()) this.listener();\n }\n\n stop() {\n webContents.removeListener(\"devtools-opened\", this.listener);\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbW9kdWxlcy9yZWFjdERldlRvb2xzLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQmV0dGVyRGlzY29yZC8uL3NyYy9tb2R1bGVzL3JlYWN0RGV2VG9vbHMuanM/OTdhZiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgVXRpbHMgZnJvbSBcIi4vdXRpbHNcIjtcbmltcG9ydCB7IHNldHRpbmdzIH0gZnJvbSBcIi4uLzBnbG9iYWxzXCI7XG5cbmNvbnN0IGVsZWN0cm9uID0gcmVxdWlyZShcImVsZWN0cm9uXCIpO1xuXG5jb25zdCBmcyA9IHJlcXVpcmUoXCJmc1wiKTtcblxuY29uc3QgcGF0aCA9IHJlcXVpcmUoXCJwYXRoXCIpO1xuXG5jb25zdCBCcm93c2VyV2luZG93ID0gZWxlY3Ryb24ucmVtb3RlLkJyb3dzZXJXaW5kb3c7XG5jb25zdCB3ZWJDb250ZW50cyA9IGVsZWN0cm9uLnJlbW90ZS5nZXRDdXJyZW50V2ViQ29udGVudHMoKTtcbmV4cG9ydCBkZWZhdWx0IG5ldyBjbGFzcyByZWFjdERldlRvb2xzIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgbGV0IGV4dGVuc2lvblBhdGggPSBcIlwiO1xuICAgIGlmIChwcm9jZXNzLnBsYXRmb3JtID09PSBcIndpbjMyXCIpIGV4dGVuc2lvblBhdGggPSBwYXRoLnJlc29sdmUocHJvY2Vzcy5lbnYuTE9DQUxBUFBEQVRBLCBcIkdvb2dsZS9DaHJvbWUvVXNlciBEYXRhXCIpO2Vsc2UgaWYgKHByb2Nlc3MucGxhdGZvcm0gPT09IFwibGludXhcIikgZXh0ZW5zaW9uUGF0aCA9IHBhdGgucmVzb2x2ZShwcm9jZXNzLmVudi5IT01FLCBcIi5jb25maWcvZ29vZ2xlLWNocm9tZVwiKTtlbHNlIGlmIChwcm9jZXNzLnBsYXRmb3JtID09PSBcImRhcndpblwiKSBleHRlbnNpb25QYXRoID0gcGF0aC5yZXNvbHZlKHByb2Nlc3MuZW52LkhPTUUsIFwiTGlicmFyeS9BcHBsaWNhdGlvbiBTdXBwb3J0L0dvb2dsZS9DaHJvbWVcIik7ZWxzZSBleHRlbnNpb25QYXRoID0gcGF0aC5yZXNvbHZlKHByb2Nlc3MuZW52LkhPTUUsIFwiLmNvbmZpZy9jaHJvbWl1bVwiKTtcbiAgICBleHRlbnNpb25QYXRoICs9IFwiL0RlZmF1bHQvRXh0ZW5zaW9ucy9mbWthZG1hcGdvZmFkb3BsamJqZmthcGRrb2llbmloaS9cIjtcblxuICAgIGlmIChmcy5leGlzdHNTeW5jKGV4dGVuc2lvblBhdGgpKSB7XG4gICAgICBjb25zdCB2ZXJzaW9ucyA9IGZzLnJlYWRkaXJTeW5jKGV4dGVuc2lvblBhdGgpO1xuICAgICAgZXh0ZW5zaW9uUGF0aCA9IHBhdGgucmVzb2x2ZShleHRlbnNpb25QYXRoLCB2ZXJzaW9uc1t2ZXJzaW9ucy5sZW5ndGggLSAxXSk7XG4gICAgfVxuXG4gICAgdGhpcy5leHRlbnNpb25QYXRoID0gZXh0ZW5zaW9uUGF0aDtcbiAgICB0aGlzLmlzRXh0ZW5zaW9uSW5zdGFsbGVkID0gZnMuZXhpc3RzU3luYyhleHRlbnNpb25QYXRoKTtcbiAgICB0aGlzLmxpc3RlbmVyID0gdGhpcy5saXN0ZW5lci5iaW5kKHRoaXMpO1xuICAgIHNldHRpbmdzW1wiUmVhY3QgRGV2VG9vbHNcIl0uaGlkZGVuID0gIXRoaXMuaXNFeHRlbnNpb25JbnN0YWxsZWQ7XG4gIH1cblxuICBsaXN0ZW5lcigpIHtcbiAgICBpZiAoIXRoaXMuaXNFeHRlbnNpb25JbnN0YWxsZWQpIHJldHVybjtcbiAgICBCcm93c2VyV2luZG93LnJlbW92ZURldlRvb2xzRXh0ZW5zaW9uKFwiUmVhY3QgRGV2ZWxvcGVyIFRvb2xzXCIpO1xuICAgIGNvbnN0IGRpZEluc3RhbGwgPSBCcm93c2VyV2luZG93LmFkZERldlRvb2xzRXh0ZW5zaW9uKHRoaXMuZXh0ZW5zaW9uUGF0aCk7XG4gICAgaWYgKGRpZEluc3RhbGwpIFV0aWxzLmxvZyhcIlJlYWN0IERldlRvb2xzXCIsIFwiU3VjY2Vzc2Z1bGx5IGluc3RhbGxlZCByZWFjdCBkZXZ0b29scy5cIik7ZWxzZSBVdGlscy5lcnIoXCJSZWFjdCBEZXZUb29sc1wiLCBcIkNvdWxkbid0IGZpbmQgcmVhY3QgZGV2dG9vbHMgaW4gY2hyb21lIGV4dGVuc2lvbnMhXCIpO1xuICB9XG5cbiAgc3RhcnQoKSB7XG4gICAgc2V0SW1tZWRpYXRlKCgpID0+IHdlYkNvbnRlbnRzLm9uKFwiZGV2dG9vbHMtb3BlbmVkXCIsIHRoaXMubGlzdGVuZXIpKTtcbiAgICBpZiAod2ViQ29udGVudHMuaXNEZXZUb29sc09wZW5lZCgpKSB0aGlzLmxpc3RlbmVyKCk7XG4gIH1cblxuICBzdG9wKCkge1xuICAgIHdlYkNvbnRlbnRzLnJlbW92ZUxpc3RlbmVyKFwiZGV2dG9vbHMtb3BlbmVkXCIsIHRoaXMubGlzdGVuZXIpO1xuICB9XG5cbn0oKTsiXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/modules/reactDevTools.js\n"); + +/***/ }), + +/***/ "./src/modules/settingsPanel.js": +/*!**************************************!*\ + !*** ./src/modules/settingsPanel.js ***! + \**************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _dataStore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./dataStore */ \"./src/modules/dataStore.js\");\n/* harmony import */ var _settingsPanelSidebar__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./settingsPanelSidebar */ \"./src/modules/settingsPanelSidebar.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _v2__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _contentManager__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./contentManager */ \"./src/modules/contentManager.js\");\n/* harmony import */ var _bdEvents__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./bdEvents */ \"./src/modules/bdEvents.js\");\n/* harmony import */ var _coloredText__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./coloredText */ \"./src/modules/coloredText.js\");\n/* harmony import */ var _24hour__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./24hour */ \"./src/modules/24hour.js\");\n/* harmony import */ var _reactDevTools__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./reactDevTools */ \"./src/modules/reactDevTools.js\");\n/* harmony import */ var _domtools__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./domtools */ \"./src/modules/domtools.js\");\n/* harmony import */ var _publicServers__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./publicServers */ \"./src/modules/publicServers.js\");\n/* harmony import */ var _voiceMode__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./voiceMode */ \"./src/modules/voiceMode.js\");\n/* harmony import */ var _classNormalizer__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./classNormalizer */ \"./src/modules/classNormalizer.js\");\n/* harmony import */ var _devMode__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./devMode */ \"./src/modules/devMode.js\");\n/* harmony import */ var _ui_tools__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ../ui/tools */ \"./src/ui/tools.js\");\n/* harmony import */ var _ui_scroller__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! ../ui/scroller */ \"./src/ui/scroller.js\");\n/* harmony import */ var _ui_sectionedSettingsPanel__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(/*! ../ui/sectionedSettingsPanel */ \"./src/ui/sectionedSettingsPanel.js\");\n/* harmony import */ var _ui_settingsPanel__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(/*! ../ui/settingsPanel */ \"./src/ui/settingsPanel.js\");\n/* harmony import */ var _ui_cssEditor__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(/*! ../ui/cssEditor */ \"./src/ui/cssEditor.js\");\n/* harmony import */ var _ui_addonlist__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(/*! ../ui/addonlist */ \"./src/ui/addonlist.jsx\");\n/* harmony import */ var _ui_presenceSettings__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(/*! ../ui/presenceSettings */ \"./src/ui/presenceSettings.jsx\");\n/* harmony import */ var _CustomRichPresence__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(/*! ./CustomRichPresence */ \"./src/modules/CustomRichPresence.js\");\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class V2_SettingsPanel {\n constructor() {\n this.sideBarOnClick = this.sideBarOnClick.bind(this);\n this.onChange = this.onChange.bind(this);\n this.updateSettings = this.updateSettings.bind(this);\n this.sidebar = new _settingsPanelSidebar__WEBPACK_IMPORTED_MODULE_2__[\"default\"](this.sideBarOnClick); // this.buildPluginProps = this.buildPluginProps.bind(this);\n // this.buildThemeProps = this.buildThemeProps.bind(this);\n\n this.showOriginal = this.showOriginal.bind(this);\n }\n\n get root() {\n const _root = _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].query(\"#bd-settingspane-container\");\n\n if (!_root) {\n if (!this.injectRoot()) return null;\n return this.root;\n }\n\n return _root;\n }\n\n injectRoot() {\n let [classNameLayer, classSidebar] = [BDModules.get(e => e.layer && e.animating)[0].layer.split(\" \")[0], BDModules.get(e => e.standardSidebarView)[0]];\n const sidebar = _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].query(\".\" + classNameLayer + \" .\" + classSidebar.standardSidebarView.split(\" \")[0] + \", .\" + classNameLayer + \" .ui-standard-sidebar-view\");\n if (!sidebar) return false;\n const root = _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].createElement(`
`);\n sidebar.append(root);\n _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].onRemoved(root, () => {\n _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].reactDom.unmountComponentAtNode(root);\n });\n return true;\n }\n\n get coreSettings() {\n const settings = this.getSettings(\"core\");\n const categories = [...new Set(settings.map(s => s.category))];\n const sections = categories.map(c => {\n return {\n title: c,\n settings: settings.filter(s => s.category == c)\n };\n });\n return sections;\n }\n\n get lightcordSettings() {\n const settings = this.getSettings(\"lightcord\");\n const categories = [...new Set(settings.map(s => s.category))];\n const sections = categories.map(c => {\n return {\n title: c,\n settings: settings.filter(s => s.category == c)\n };\n });\n return sections;\n }\n\n get PresenceSettings() {\n return this.getSettings(\"status\");\n }\n\n getSettings(category) {\n return Object.keys(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settings\"]).reduce((arr, key) => {\n const setting = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settings\"][key];\n\n if (setting.cat === category && setting.implemented && !setting.hidden) {\n setting.text = key;\n arr.push(setting);\n }\n\n return arr;\n }, []);\n }\n\n sideBarOnClick(id) {\n const contentRegion = _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].query(\".contentRegion-3nDuYy, .content-region\");\n contentRegion.style.display = \"none\";\n this.root.style.display = \"\";\n\n switch (id) {\n case \"core\":\n this.renderCoreSettings();\n break;\n\n case \"customcss\":\n this.renderCustomCssEditor();\n break;\n\n case \"plugins\":\n case \"themes\":\n this.renderAddonPane(id);\n break;\n\n case \"lightcord\":\n this.renderLightCordSettings();\n break;\n\n case \"status\":\n this.renderPresenceSettings();\n }\n }\n\n onClick() {}\n\n onChange(id, checked) {\n this.updateSettings(id, checked);\n }\n\n updateSettings(id, enabled) {\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][id] = enabled;\n\n if (id == \"bda-gs-2\") {\n if (enabled) _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].addClass(document.body, \"bd-minimal\");else _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].removeClass(document.body, \"bd-minimal\");\n }\n\n if (id == \"bda-gs-3\") {\n if (enabled) _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].addClass(document.body, \"bd-minimal-chan\");else _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].removeClass(document.body, \"bd-minimal-chan\");\n }\n\n if (id == \"bda-gs-1\") {\n if (enabled) _publicServers__WEBPACK_IMPORTED_MODULE_11__[\"default\"].addButton();else _publicServers__WEBPACK_IMPORTED_MODULE_11__[\"default\"].removeButton();\n }\n\n if (id == \"bda-gs-4\") {\n if (enabled) _voiceMode__WEBPACK_IMPORTED_MODULE_12__[\"default\"].start();else _voiceMode__WEBPACK_IMPORTED_MODULE_12__[\"default\"].stop();\n }\n\n if (id == \"bda-gs-5\") {\n if (enabled) _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].addClass(_domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].query(\"#app-mount\"), \"bda-dark\");else _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].removeClass(_domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].query(\"#app-mount\"), \"bda-dark\");\n }\n\n if (enabled && id == \"bda-gs-6\") _24hour__WEBPACK_IMPORTED_MODULE_8__[\"default\"].inject24Hour();\n\n if (id == \"bda-gs-7\") {\n if (enabled) _coloredText__WEBPACK_IMPORTED_MODULE_7__[\"default\"].injectColoredText();else _coloredText__WEBPACK_IMPORTED_MODULE_7__[\"default\"].removeColoredText();\n }\n\n if (id == \"fork-ps-4\") {\n if (enabled) _classNormalizer__WEBPACK_IMPORTED_MODULE_13__[\"default\"].start();else _classNormalizer__WEBPACK_IMPORTED_MODULE_13__[\"default\"].stop();\n }\n\n if (id == \"fork-ps-5\") {\n if (enabled) {\n _contentManager__WEBPACK_IMPORTED_MODULE_5__[\"default\"].watchContent(\"plugin\");\n _contentManager__WEBPACK_IMPORTED_MODULE_5__[\"default\"].watchContent(\"theme\");\n } else {\n _contentManager__WEBPACK_IMPORTED_MODULE_5__[\"default\"].unwatchContent(\"plugin\");\n _contentManager__WEBPACK_IMPORTED_MODULE_5__[\"default\"].unwatchContent(\"theme\");\n }\n }\n\n if (id == \"fork-wp-1\") {\n _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].setWindowPreference(\"transparent\", enabled);\n if (enabled) _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].setWindowPreference(\"backgroundColor\", null);else _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].setWindowPreference(\"backgroundColor\", \"#2f3136\");\n }\n\n if (id == \"bda-gs-8\") {\n if (enabled) _devMode__WEBPACK_IMPORTED_MODULE_14__[\"default\"].startDebugListener();else _devMode__WEBPACK_IMPORTED_MODULE_14__[\"default\"].stopDebugListener();\n }\n\n if (id == \"fork-dm-1\") {\n if (enabled) _devMode__WEBPACK_IMPORTED_MODULE_14__[\"default\"].startCopySelector();else _devMode__WEBPACK_IMPORTED_MODULE_14__[\"default\"].stopCopySelector();\n }\n\n if (id === \"reactDevTools\") {\n if (enabled) _reactDevTools__WEBPACK_IMPORTED_MODULE_9__[\"default\"].start();else _reactDevTools__WEBPACK_IMPORTED_MODULE_9__[\"default\"].stop();\n }\n\n if (id === \"lightcord-1\") {\n if (enabled) window.lightcordSettings.devMode = true;else window.lightcordSettings.devMode = false;\n }\n\n if (id === \"lightcord-2\") {\n if (enabled) window.lightcordSettings.callRingingBeat = true;else window.lightcordSettings.callRingingBeat = false;\n }\n\n if (id === \"lightcord-presence-1\") {\n if (enabled) _CustomRichPresence__WEBPACK_IMPORTED_MODULE_22__[\"default\"].enable();else _CustomRichPresence__WEBPACK_IMPORTED_MODULE_22__[\"default\"].disable();\n }\n\n this.saveSettings();\n }\n\n async initializeSettings() {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"].reactDevTools) _reactDevTools__WEBPACK_IMPORTED_MODULE_9__[\"default\"].start();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-gs-2\"]) _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].addClass(document.body, \"bd-minimal\");\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-gs-3\"]) _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].addClass(document.body, \"bd-minimal-chan\");\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-gs-1\"]) _publicServers__WEBPACK_IMPORTED_MODULE_11__[\"default\"].addButton();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-gs-4\"]) _voiceMode__WEBPACK_IMPORTED_MODULE_12__[\"default\"].start();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-gs-5\"]) _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].addClass(_domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].query(\"#app-mount\"), \"bda-dark\");\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-gs-6\"]) _24hour__WEBPACK_IMPORTED_MODULE_8__[\"default\"].inject24Hour();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-gs-7\"]) _coloredText__WEBPACK_IMPORTED_MODULE_7__[\"default\"].injectColoredText();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-4\"]) _classNormalizer__WEBPACK_IMPORTED_MODULE_13__[\"default\"].start();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"lightcord-1\"]) window.lightcordSettings.devMode = true;\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"lightcord-2\"]) window.lightcordSettings.callRingingBeat = true;\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"lightcord-presence-1\"]) _CustomRichPresence__WEBPACK_IMPORTED_MODULE_22__[\"default\"].enable();\n\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-5\"]) {\n _contentManager__WEBPACK_IMPORTED_MODULE_5__[\"default\"].watchContent(\"plugin\");\n _contentManager__WEBPACK_IMPORTED_MODULE_5__[\"default\"].watchContent(\"theme\");\n }\n\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-gs-8\"]) _devMode__WEBPACK_IMPORTED_MODULE_14__[\"default\"].startDebugListener();\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-dm-1\"]) _devMode__WEBPACK_IMPORTED_MODULE_14__[\"default\"].startCopySelector();\n this.saveSettings();\n }\n\n saveSettings() {\n _dataStore__WEBPACK_IMPORTED_MODULE_1__[\"default\"].setSettingGroup(\"settings\", _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"]);\n }\n\n loadSettings() {\n Object.assign(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"], _dataStore__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getSettingGroup(\"settings\"));\n }\n\n showOriginal() {\n _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].reactDom.unmountComponentAtNode(this.root);\n this.root.style.display = \"none\";\n _domtools__WEBPACK_IMPORTED_MODULE_10__[\"default\"].query(\".\" + BDModules.get(e => e.contentRegion)[0].contentRegion.split(\" \")[0] + \", .content-region\").style.display = \"\";\n }\n\n renderSidebar() {\n const tabs = document.querySelectorAll(\"[class*='side-'] > [class*='item-']\");\n\n for (const element of tabs) {\n element.removeEventListener(\"click\", this.showOriginal);\n element.addEventListener(\"click\", this.showOriginal);\n }\n\n this.sidebar.render();\n }\n\n get coreComponent() {\n return _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_scroller__WEBPACK_IMPORTED_MODULE_16__[\"default\"], {\n contentColumn: true,\n fade: true,\n dark: true\n }, _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_sectionedSettingsPanel__WEBPACK_IMPORTED_MODULE_17__[\"default\"], {\n key: \"cspanel\",\n onChange: this.onChange,\n sections: this.coreSettings\n }), _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_tools__WEBPACK_IMPORTED_MODULE_15__[\"default\"], {\n key: \"tools\"\n }));\n }\n\n get lightcordComponent() {\n return _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_scroller__WEBPACK_IMPORTED_MODULE_16__[\"default\"], {\n contentColumn: true,\n fade: true,\n dark: true\n }, _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_sectionedSettingsPanel__WEBPACK_IMPORTED_MODULE_17__[\"default\"], {\n key: \"lspannel\",\n onChange: this.onChange,\n sections: this.lightcordSettings\n }), _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_tools__WEBPACK_IMPORTED_MODULE_15__[\"default\"], {\n key: \"tools\"\n }));\n }\n\n get PresenceComponent() {\n return _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_scroller__WEBPACK_IMPORTED_MODULE_16__[\"default\"], {\n contentColumn: true,\n fade: true,\n dark: true\n }, _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_presenceSettings__WEBPACK_IMPORTED_MODULE_21__[\"default\"], {\n key: \"lspannel\",\n onChange: this.onChange,\n settings: this.PresenceSettings\n }), _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_tools__WEBPACK_IMPORTED_MODULE_15__[\"default\"], {\n key: \"tools\"\n }));\n }\n\n get customCssComponent() {\n return _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_scroller__WEBPACK_IMPORTED_MODULE_16__[\"default\"], {\n contentColumn: true,\n fade: true,\n dark: true\n }, _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_cssEditor__WEBPACK_IMPORTED_MODULE_19__[\"default\"], {\n key: \"csseditor\"\n }), _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_tools__WEBPACK_IMPORTED_MODULE_15__[\"default\"], {\n key: \"tools\"\n }));\n }\n\n renderCoreSettings() {\n const root = this.root;\n if (!root) return _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\");\n _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].reactDom.render(this.coreComponent, root);\n }\n\n renderLightCordSettings() {\n const root = this.root;\n if (!root) return _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\");\n _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].reactDom.render(this.lightcordComponent, root);\n }\n\n renderPresenceSettings() {\n const root = this.root;\n if (!root) return _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\");\n _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].reactDom.render(this.PresenceComponent, root);\n }\n\n renderCustomCssEditor() {\n const root = this.root;\n if (!root) return _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\");\n _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].reactDom.render(this.customCssComponent, root);\n } // renderAddonPane(type) {\n // const root = this.root;\n // if (!root) return Utils.err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\");\n // BDV2.reactDom.render(this.contentComponent(type), root);\n // }\n\n\n renderAddonPane(type) {\n if (!this.root) return _utils__WEBPACK_IMPORTED_MODULE_3__[\"default\"].err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\"); // I know this shouldn't be here, but when it isn't,\n // React refuses to change the button when going\n // between plugins and themes page... something\n // to debug later.\n\n class ContentList extends _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.Component {\n constructor(props) {\n super(props);\n this.prefix = this.props.type.replace(\"s\", \"\");\n this.onChange = this.onChange.bind(this);\n }\n\n componentDidMount() {\n _bdEvents__WEBPACK_IMPORTED_MODULE_6__[\"default\"].on(`${this.prefix}-reloaded`, this.onChange);\n _bdEvents__WEBPACK_IMPORTED_MODULE_6__[\"default\"].on(`${this.prefix}-loaded`, this.onChange);\n _bdEvents__WEBPACK_IMPORTED_MODULE_6__[\"default\"].on(`${this.prefix}-unloaded`, this.onChange);\n }\n\n componentWillUnmount() {\n _bdEvents__WEBPACK_IMPORTED_MODULE_6__[\"default\"].off(`${this.prefix}-reloaded`, this.onChange);\n _bdEvents__WEBPACK_IMPORTED_MODULE_6__[\"default\"].off(`${this.prefix}-loaded`, this.onChange);\n _bdEvents__WEBPACK_IMPORTED_MODULE_6__[\"default\"].off(`${this.prefix}-unloaded`, this.onChange);\n }\n\n onChange() {\n this.props.onChange(this.props.type);\n }\n\n render() {\n return this.props.children;\n }\n\n }\n\n const list = type === \"plugins\" ? Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdplugins\"]) : Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"]);\n return _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].reactDom.render(_v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(ContentList, {\n type,\n onChange: this.sideBarOnClick\n }, _v2__WEBPACK_IMPORTED_MODULE_4__[\"default\"].react.createElement(_ui_addonlist__WEBPACK_IMPORTED_MODULE_20__[\"default\"], {\n type,\n list\n })), this.root);\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/modules/settingsPanel.js.js","sources":["webpack://BetterDiscord/./src/modules/settingsPanel.js?57b0"],"sourcesContent":["import { settings, settingsCookie, bdplugins, bdthemes } from \"../0globals\";\nimport DataStore from \"./dataStore\";\nimport V2_SettingsPanel_Sidebar from \"./settingsPanelSidebar\";\nimport Utils from \"./utils\";\nimport BDV2 from \"./v2\";\nimport ContentManager from \"./contentManager\";\nimport BDEvents from \"./bdEvents\";\nimport coloredText from \"./coloredText\";\nimport tfHour from \"./24hour\";\nimport reactDevTools from \"./reactDevTools\";\nimport DOM from \"./domtools\";\nimport publicServersModule from \"./publicServers\";\nimport voiceMode from \"./voiceMode\";\nimport ClassNormalizer from \"./classNormalizer\";\nimport dMode from \"./devMode\";\nimport Tools from \"../ui/tools\";\nimport Scroller from \"../ui/scroller\";\nimport SectionedSettingsPanel from \"../ui/sectionedSettingsPanel\";\nimport SettingsPanel from \"../ui/settingsPanel\";\nimport CssEditor from \"../ui/cssEditor\";\nimport CardList from \"../ui/addonlist\";\nimport V2C_PresenceSettings from \"../ui/presenceSettings\";\nimport CustomRichPresence from \"./CustomRichPresence\";\nexport default new class V2_SettingsPanel {\n  constructor() {\n    this.sideBarOnClick = this.sideBarOnClick.bind(this);\n    this.onChange = this.onChange.bind(this);\n    this.updateSettings = this.updateSettings.bind(this);\n    this.sidebar = new V2_SettingsPanel_Sidebar(this.sideBarOnClick); // this.buildPluginProps = this.buildPluginProps.bind(this);\n    // this.buildThemeProps = this.buildThemeProps.bind(this);\n\n    this.showOriginal = this.showOriginal.bind(this);\n  }\n\n  get root() {\n    const _root = DOM.query(\"#bd-settingspane-container\");\n\n    if (!_root) {\n      if (!this.injectRoot()) return null;\n      return this.root;\n    }\n\n    return _root;\n  }\n\n  injectRoot() {\n    let [classNameLayer, classSidebar] = [BDModules.get(e => e.layer && e.animating)[0].layer.split(\" \")[0], BDModules.get(e => e.standardSidebarView)[0]];\n    const sidebar = DOM.query(\".\" + classNameLayer + \" .\" + classSidebar.standardSidebarView.split(\" \")[0] + \", .\" + classNameLayer + \" .ui-standard-sidebar-view\");\n    if (!sidebar) return false;\n    const root = DOM.createElement(`<div id=\"bd-settingspane-container\" class=\"${classSidebar.contentRegion} content-region\">`);\n    sidebar.append(root);\n    Utils.onRemoved(root, () => {\n      BDV2.reactDom.unmountComponentAtNode(root);\n    });\n    return true;\n  }\n\n  get coreSettings() {\n    const settings = this.getSettings(\"core\");\n    const categories = [...new Set(settings.map(s => s.category))];\n    const sections = categories.map(c => {\n      return {\n        title: c,\n        settings: settings.filter(s => s.category == c)\n      };\n    });\n    return sections;\n  }\n\n  get lightcordSettings() {\n    const settings = this.getSettings(\"lightcord\");\n    const categories = [...new Set(settings.map(s => s.category))];\n    const sections = categories.map(c => {\n      return {\n        title: c,\n        settings: settings.filter(s => s.category == c)\n      };\n    });\n    return sections;\n  }\n\n  get PresenceSettings() {\n    return this.getSettings(\"status\");\n  }\n\n  getSettings(category) {\n    return Object.keys(settings).reduce((arr, key) => {\n      const setting = settings[key];\n\n      if (setting.cat === category && setting.implemented && !setting.hidden) {\n        setting.text = key;\n        arr.push(setting);\n      }\n\n      return arr;\n    }, []);\n  }\n\n  sideBarOnClick(id) {\n    const contentRegion = DOM.query(\".contentRegion-3nDuYy, .content-region\");\n    contentRegion.style.display = \"none\";\n    this.root.style.display = \"\";\n\n    switch (id) {\n      case \"core\":\n        this.renderCoreSettings();\n        break;\n\n      case \"customcss\":\n        this.renderCustomCssEditor();\n        break;\n\n      case \"plugins\":\n      case \"themes\":\n        this.renderAddonPane(id);\n        break;\n\n      case \"lightcord\":\n        this.renderLightCordSettings();\n        break;\n\n      case \"status\":\n        this.renderPresenceSettings();\n    }\n  }\n\n  onClick() {}\n\n  onChange(id, checked) {\n    this.updateSettings(id, checked);\n  }\n\n  updateSettings(id, enabled) {\n    settingsCookie[id] = enabled;\n\n    if (id == \"bda-gs-2\") {\n      if (enabled) DOM.addClass(document.body, \"bd-minimal\");else DOM.removeClass(document.body, \"bd-minimal\");\n    }\n\n    if (id == \"bda-gs-3\") {\n      if (enabled) DOM.addClass(document.body, \"bd-minimal-chan\");else DOM.removeClass(document.body, \"bd-minimal-chan\");\n    }\n\n    if (id == \"bda-gs-1\") {\n      if (enabled) publicServersModule.addButton();else publicServersModule.removeButton();\n    }\n\n    if (id == \"bda-gs-4\") {\n      if (enabled) voiceMode.start();else voiceMode.stop();\n    }\n\n    if (id == \"bda-gs-5\") {\n      if (enabled) DOM.addClass(DOM.query(\"#app-mount\"), \"bda-dark\");else DOM.removeClass(DOM.query(\"#app-mount\"), \"bda-dark\");\n    }\n\n    if (enabled && id == \"bda-gs-6\") tfHour.inject24Hour();\n\n    if (id == \"bda-gs-7\") {\n      if (enabled) coloredText.injectColoredText();else coloredText.removeColoredText();\n    }\n\n    if (id == \"fork-ps-4\") {\n      if (enabled) ClassNormalizer.start();else ClassNormalizer.stop();\n    }\n\n    if (id == \"fork-ps-5\") {\n      if (enabled) {\n        ContentManager.watchContent(\"plugin\");\n        ContentManager.watchContent(\"theme\");\n      } else {\n        ContentManager.unwatchContent(\"plugin\");\n        ContentManager.unwatchContent(\"theme\");\n      }\n    }\n\n    if (id == \"fork-wp-1\") {\n      Utils.setWindowPreference(\"transparent\", enabled);\n      if (enabled) Utils.setWindowPreference(\"backgroundColor\", null);else Utils.setWindowPreference(\"backgroundColor\", \"#2f3136\");\n    }\n\n    if (id == \"bda-gs-8\") {\n      if (enabled) dMode.startDebugListener();else dMode.stopDebugListener();\n    }\n\n    if (id == \"fork-dm-1\") {\n      if (enabled) dMode.startCopySelector();else dMode.stopCopySelector();\n    }\n\n    if (id === \"reactDevTools\") {\n      if (enabled) reactDevTools.start();else reactDevTools.stop();\n    }\n\n    if (id === \"lightcord-1\") {\n      if (enabled) window.lightcordSettings.devMode = true;else window.lightcordSettings.devMode = false;\n    }\n\n    if (id === \"lightcord-2\") {\n      if (enabled) window.lightcordSettings.callRingingBeat = true;else window.lightcordSettings.callRingingBeat = false;\n    }\n\n    if (id === \"lightcord-presence-1\") {\n      if (enabled) CustomRichPresence.enable();else CustomRichPresence.disable();\n    }\n\n    this.saveSettings();\n  }\n\n  async initializeSettings() {\n    if (settingsCookie.reactDevTools) reactDevTools.start();\n    if (settingsCookie[\"bda-gs-2\"]) DOM.addClass(document.body, \"bd-minimal\");\n    if (settingsCookie[\"bda-gs-3\"]) DOM.addClass(document.body, \"bd-minimal-chan\");\n    if (settingsCookie[\"bda-gs-1\"]) publicServersModule.addButton();\n    if (settingsCookie[\"bda-gs-4\"]) voiceMode.start();\n    if (settingsCookie[\"bda-gs-5\"]) DOM.addClass(DOM.query(\"#app-mount\"), \"bda-dark\");\n    if (settingsCookie[\"bda-gs-6\"]) tfHour.inject24Hour();\n    if (settingsCookie[\"bda-gs-7\"]) coloredText.injectColoredText();\n    if (settingsCookie[\"fork-ps-4\"]) ClassNormalizer.start();\n    if (settingsCookie[\"lightcord-1\"]) window.lightcordSettings.devMode = true;\n    if (settingsCookie[\"lightcord-2\"]) window.lightcordSettings.callRingingBeat = true;\n    if (settingsCookie[\"lightcord-presence-1\"]) CustomRichPresence.enable();\n\n    if (settingsCookie[\"fork-ps-5\"]) {\n      ContentManager.watchContent(\"plugin\");\n      ContentManager.watchContent(\"theme\");\n    }\n\n    if (settingsCookie[\"bda-gs-8\"]) dMode.startDebugListener();\n    if (settingsCookie[\"fork-dm-1\"]) dMode.startCopySelector();\n    this.saveSettings();\n  }\n\n  saveSettings() {\n    DataStore.setSettingGroup(\"settings\", settingsCookie);\n  }\n\n  loadSettings() {\n    Object.assign(settingsCookie, DataStore.getSettingGroup(\"settings\"));\n  }\n\n  showOriginal() {\n    BDV2.reactDom.unmountComponentAtNode(this.root);\n    this.root.style.display = \"none\";\n    DOM.query(\".\" + BDModules.get(e => e.contentRegion)[0].contentRegion.split(\" \")[0] + \", .content-region\").style.display = \"\";\n  }\n\n  renderSidebar() {\n    const tabs = document.querySelectorAll(\"[class*='side-'] > [class*='item-']\");\n\n    for (const element of tabs) {\n      element.removeEventListener(\"click\", this.showOriginal);\n      element.addEventListener(\"click\", this.showOriginal);\n    }\n\n    this.sidebar.render();\n  }\n\n  get coreComponent() {\n    return BDV2.react.createElement(Scroller, {\n      contentColumn: true,\n      fade: true,\n      dark: true\n    }, BDV2.react.createElement(SectionedSettingsPanel, {\n      key: \"cspanel\",\n      onChange: this.onChange,\n      sections: this.coreSettings\n    }), BDV2.react.createElement(Tools, {\n      key: \"tools\"\n    }));\n  }\n\n  get lightcordComponent() {\n    return BDV2.react.createElement(Scroller, {\n      contentColumn: true,\n      fade: true,\n      dark: true\n    }, BDV2.react.createElement(SectionedSettingsPanel, {\n      key: \"lspannel\",\n      onChange: this.onChange,\n      sections: this.lightcordSettings\n    }), BDV2.react.createElement(Tools, {\n      key: \"tools\"\n    }));\n  }\n\n  get PresenceComponent() {\n    return BDV2.react.createElement(Scroller, {\n      contentColumn: true,\n      fade: true,\n      dark: true\n    }, BDV2.react.createElement(V2C_PresenceSettings, {\n      key: \"lspannel\",\n      onChange: this.onChange,\n      settings: this.PresenceSettings\n    }), BDV2.react.createElement(Tools, {\n      key: \"tools\"\n    }));\n  }\n\n  get customCssComponent() {\n    return BDV2.react.createElement(Scroller, {\n      contentColumn: true,\n      fade: true,\n      dark: true\n    }, BDV2.react.createElement(CssEditor, {\n      key: \"csseditor\"\n    }), BDV2.react.createElement(Tools, {\n      key: \"tools\"\n    }));\n  }\n\n  renderCoreSettings() {\n    const root = this.root;\n    if (!root) return Utils.err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\");\n    BDV2.reactDom.render(this.coreComponent, root);\n  }\n\n  renderLightCordSettings() {\n    const root = this.root;\n    if (!root) return Utils.err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\");\n    BDV2.reactDom.render(this.lightcordComponent, root);\n  }\n\n  renderPresenceSettings() {\n    const root = this.root;\n    if (!root) return Utils.err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\");\n    BDV2.reactDom.render(this.PresenceComponent, root);\n  }\n\n  renderCustomCssEditor() {\n    const root = this.root;\n    if (!root) return Utils.err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\");\n    BDV2.reactDom.render(this.customCssComponent, root);\n  } // renderAddonPane(type) {\n  //     const root = this.root;\n  //     if (!root) return Utils.err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\");\n  //     BDV2.reactDom.render(this.contentComponent(type), root);\n  // }\n\n\n  renderAddonPane(type) {\n    if (!this.root) return Utils.err(\"SettingsPanel\", \"FAILED TO LOCATE ROOT: .layer-3QrUeG .standardSidebarView-3F1I7i\"); // I know this shouldn't be here, but when it isn't,\n    // React refuses to change the button when going\n    // between plugins and themes page... something\n    // to debug later.\n\n    class ContentList extends BDV2.react.Component {\n      constructor(props) {\n        super(props);\n        this.prefix = this.props.type.replace(\"s\", \"\");\n        this.onChange = this.onChange.bind(this);\n      }\n\n      componentDidMount() {\n        BDEvents.on(`${this.prefix}-reloaded`, this.onChange);\n        BDEvents.on(`${this.prefix}-loaded`, this.onChange);\n        BDEvents.on(`${this.prefix}-unloaded`, this.onChange);\n      }\n\n      componentWillUnmount() {\n        BDEvents.off(`${this.prefix}-reloaded`, this.onChange);\n        BDEvents.off(`${this.prefix}-loaded`, this.onChange);\n        BDEvents.off(`${this.prefix}-unloaded`, this.onChange);\n      }\n\n      onChange() {\n        this.props.onChange(this.props.type);\n      }\n\n      render() {\n        return this.props.children;\n      }\n\n    }\n\n    const list = type === \"plugins\" ? Object.values(bdplugins) : Object.values(bdthemes);\n    return BDV2.reactDom.render(BDV2.react.createElement(ContentList, {\n      type,\n      onChange: this.sideBarOnClick\n    }, BDV2.react.createElement(CardList, {\n      type,\n      list\n    })), this.root);\n  }\n\n}();"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/modules/settingsPanel.js\n"); + +/***/ }), + +/***/ "./src/modules/settingsPanelSidebar.js": +/*!*********************************************!*\ + !*** ./src/modules/settingsPanelSidebar.js ***! + \*********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2_SettingsPanel_Sidebar; });\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _v2__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _domtools__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./domtools */ \"./src/modules/domtools.js\");\n/* harmony import */ var _ui_sidebar__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../ui/sidebar */ \"./src/ui/sidebar.js\");\n/* harmony import */ var _ui_icons_history__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../ui/icons/history */ \"./src/ui/icons/history.jsx\");\n/* harmony import */ var _ui_tooltipWrap__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../ui/tooltipWrap */ \"./src/ui/tooltipWrap.js\");\n\n\n\n\n\n\n\nclass V2_SettingsPanel_Sidebar {\n constructor(onClick) {\n this.onClick = onClick;\n }\n\n get items() {\n return [{\n text: \"Lightcord\",\n id: \"lightcord\"\n }, {\n text: \"Settings\",\n id: \"core\"\n }, {\n text: \"Plugins\",\n id: \"plugins\"\n }, {\n text: \"Themes\",\n id: \"themes\"\n }, {\n text: \"Custom CSS\",\n id: \"customcss\"\n }, {\n text: \"Presence\",\n id: \"status\"\n }];\n }\n\n get component() {\n //\n const changelogButton = _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(_ui_tooltipWrap__WEBPACK_IMPORTED_MODULE_6__[\"default\"], {\n color: \"black\",\n side: \"top\",\n text: \"Changelog\"\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n className: \"bd-changelog-button\",\n onClick: () => {\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].showChangelogModal(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bbdChangelog\"]);\n }\n }, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(_ui_icons_history__WEBPACK_IMPORTED_MODULE_5__[\"default\"], {\n className: \"bd-icon\",\n size: \"16px\"\n })));\n return _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"span\", null, _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(_ui_sidebar__WEBPACK_IMPORTED_MODULE_4__[\"default\"], {\n onClick: this.onClick,\n headerText: \"Bandaged BD\",\n headerButton: changelogButton,\n items: this.items\n }));\n }\n\n get root() {\n const _root = _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].query(\"#bd-settings-sidebar\");\n\n if (!_root) {\n if (!this.injectRoot()) return null;\n return this.root;\n }\n\n return _root;\n }\n\n injectRoot() {\n const tabs = _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].queryAll(\"[class*='side-'] > [class*='item-']:not([class*=Danger])\");\n const changeLog = tabs[tabs.length - 1];\n if (!changeLog) return false;\n changeLog.parentElement.insertBefore(_domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].createElement(`
`), changeLog.previousElementSibling);\n return true;\n }\n\n render() {\n const root = this.root;\n\n if (!root) {\n console.log(\"FAILED TO LOCATE ROOT: [class*='side-'] > [class*='item-']:not([class*=Danger])\");\n return;\n }\n\n _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].reactDom.render(this.component, root);\n _utils__WEBPACK_IMPORTED_MODULE_1__[\"default\"].onRemoved(root, () => {\n _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].reactDom.unmountComponentAtNode(root);\n });\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbW9kdWxlcy9zZXR0aW5nc1BhbmVsU2lkZWJhci5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvbW9kdWxlcy9zZXR0aW5nc1BhbmVsU2lkZWJhci5qcz85ZTA2Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJiZENoYW5nZWxvZyB9IGZyb20gXCIuLi8wZ2xvYmFsc1wiO1xuaW1wb3J0IFV0aWxzIGZyb20gXCIuL3V0aWxzXCI7XG5pbXBvcnQgQkRWMiBmcm9tIFwiLi92MlwiO1xuaW1wb3J0IERPTSBmcm9tIFwiLi9kb210b29sc1wiO1xuaW1wb3J0IFNpZGVCYXIgZnJvbSBcIi4uL3VpL3NpZGViYXJcIjtcbmltcG9ydCBIaXN0b3J5IGZyb20gXCIuLi91aS9pY29ucy9oaXN0b3J5XCI7XG5pbXBvcnQgVG9vbHRpcFdyYXAgZnJvbSBcIi4uL3VpL3Rvb2x0aXBXcmFwXCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWMl9TZXR0aW5nc1BhbmVsX1NpZGViYXIge1xuICBjb25zdHJ1Y3RvcihvbkNsaWNrKSB7XG4gICAgdGhpcy5vbkNsaWNrID0gb25DbGljaztcbiAgfVxuXG4gIGdldCBpdGVtcygpIHtcbiAgICByZXR1cm4gW3tcbiAgICAgIHRleHQ6IFwiTGlnaHRjb3JkXCIsXG4gICAgICBpZDogXCJsaWdodGNvcmRcIlxuICAgIH0sIHtcbiAgICAgIHRleHQ6IFwiU2V0dGluZ3NcIixcbiAgICAgIGlkOiBcImNvcmVcIlxuICAgIH0sIHtcbiAgICAgIHRleHQ6IFwiUGx1Z2luc1wiLFxuICAgICAgaWQ6IFwicGx1Z2luc1wiXG4gICAgfSwge1xuICAgICAgdGV4dDogXCJUaGVtZXNcIixcbiAgICAgIGlkOiBcInRoZW1lc1wiXG4gICAgfSwge1xuICAgICAgdGV4dDogXCJDdXN0b20gQ1NTXCIsXG4gICAgICBpZDogXCJjdXN0b21jc3NcIlxuICAgIH0sIHtcbiAgICAgIHRleHQ6IFwiUHJlc2VuY2VcIixcbiAgICAgIGlkOiBcInN0YXR1c1wiXG4gICAgfV07XG4gIH1cblxuICBnZXQgY29tcG9uZW50KCkge1xuICAgIC8vPFRvb2x0aXBXcmFwIGNvbG9yPVwiYmxhY2tcIiBzaWRlPVwidG9wXCIgdGV4dD17dGl0bGV9PlxuICAgIGNvbnN0IGNoYW5nZWxvZ0J1dHRvbiA9IEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChUb29sdGlwV3JhcCwge1xuICAgICAgY29sb3I6IFwiYmxhY2tcIixcbiAgICAgIHNpZGU6IFwidG9wXCIsXG4gICAgICB0ZXh0OiBcIkNoYW5nZWxvZ1wiXG4gICAgfSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJiZC1jaGFuZ2Vsb2ctYnV0dG9uXCIsXG4gICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgIFV0aWxzLnNob3dDaGFuZ2Vsb2dNb2RhbChiYmRDaGFuZ2Vsb2cpO1xuICAgICAgfVxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChIaXN0b3J5LCB7XG4gICAgICBjbGFzc05hbWU6IFwiYmQtaWNvblwiLFxuICAgICAgc2l6ZTogXCIxNnB4XCJcbiAgICB9KSkpO1xuICAgIHJldHVybiBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJzcGFuXCIsIG51bGwsIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChTaWRlQmFyLCB7XG4gICAgICBvbkNsaWNrOiB0aGlzLm9uQ2xpY2ssXG4gICAgICBoZWFkZXJUZXh0OiBcIkJhbmRhZ2VkIEJEXCIsXG4gICAgICBoZWFkZXJCdXR0b246IGNoYW5nZWxvZ0J1dHRvbixcbiAgICAgIGl0ZW1zOiB0aGlzLml0ZW1zXG4gICAgfSkpO1xuICB9XG5cbiAgZ2V0IHJvb3QoKSB7XG4gICAgY29uc3QgX3Jvb3QgPSBET00ucXVlcnkoXCIjYmQtc2V0dGluZ3Mtc2lkZWJhclwiKTtcblxuICAgIGlmICghX3Jvb3QpIHtcbiAgICAgIGlmICghdGhpcy5pbmplY3RSb290KCkpIHJldHVybiBudWxsO1xuICAgICAgcmV0dXJuIHRoaXMucm9vdDtcbiAgICB9XG5cbiAgICByZXR1cm4gX3Jvb3Q7XG4gIH1cblxuICBpbmplY3RSb290KCkge1xuICAgIGNvbnN0IHRhYnMgPSBET00ucXVlcnlBbGwoXCJbY2xhc3MqPSdzaWRlLSddID4gW2NsYXNzKj0naXRlbS0nXTpub3QoW2NsYXNzKj1EYW5nZXJdKVwiKTtcbiAgICBjb25zdCBjaGFuZ2VMb2cgPSB0YWJzW3RhYnMubGVuZ3RoIC0gMV07XG4gICAgaWYgKCFjaGFuZ2VMb2cpIHJldHVybiBmYWxzZTtcbiAgICBjaGFuZ2VMb2cucGFyZW50RWxlbWVudC5pbnNlcnRCZWZvcmUoRE9NLmNyZWF0ZUVsZW1lbnQoYDxkaXYgaWQ9XCJiZC1zZXR0aW5ncy1zaWRlYmFyXCI+YCksIGNoYW5nZUxvZy5wcmV2aW91c0VsZW1lbnRTaWJsaW5nKTtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCByb290ID0gdGhpcy5yb290O1xuXG4gICAgaWYgKCFyb290KSB7XG4gICAgICBjb25zb2xlLmxvZyhcIkZBSUxFRCBUTyBMT0NBVEUgUk9PVDogW2NsYXNzKj0nc2lkZS0nXSA+IFtjbGFzcyo9J2l0ZW0tJ106bm90KFtjbGFzcyo9RGFuZ2VyXSlcIik7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgQkRWMi5yZWFjdERvbS5yZW5kZXIodGhpcy5jb21wb25lbnQsIHJvb3QpO1xuICAgIFV0aWxzLm9uUmVtb3ZlZChyb290LCAoKSA9PiB7XG4gICAgICBCRFYyLnJlYWN0RG9tLnVubW91bnRDb21wb25lbnRBdE5vZGUocm9vdCk7XG4gICAgfSk7XG4gIH1cblxufSJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/modules/settingsPanelSidebar.js\n"); + +/***/ }), + +/***/ "./src/modules/themeModule.js": +/*!************************************!*\ + !*** ./src/modules/themeModule.js ***! + \************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _contentManager__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./contentManager */ \"./src/modules/contentManager.js\");\n/* harmony import */ var _dataStore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./dataStore */ \"./src/modules/dataStore.js\");\n/* harmony import */ var _bdEvents__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./bdEvents */ \"./src/modules/bdEvents.js\");\n/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _domtools__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./domtools */ \"./src/modules/domtools.js\");\n\n\n\n\n\n\n\nclass ThemeModule {\n get folder() {\n return _contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].themesFolder;\n }\n\n}\n\nThemeModule.prototype.loadThemes = function () {\n this.loadThemeData();\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemeErrors\"].splice(0, 0, ..._contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].loadThemes());\n const themes = Object.keys(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"]);\n\n for (let i = 0; i < themes.length; i++) {\n const theme = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][themes[i]];\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"][theme.name]) _0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"][theme.name] = false;\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"][theme.name]) _domtools__WEBPACK_IMPORTED_MODULE_5__[\"default\"].addStyle(_domtools__WEBPACK_IMPORTED_MODULE_5__[\"default\"].escapeID(theme.id), unescape(theme.css));\n }\n\n for (const theme in _0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"]) {\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][theme]) delete _0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"][theme];\n }\n\n this.saveThemeData(); // if (settingsCookie[\"fork-ps-5\"]) ContentManager.watchContent(\"theme\");\n};\n\nThemeModule.prototype.enableTheme = function (name, reload = false) {\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"][name] = true;\n this.saveThemeData();\n const theme = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][name];\n _domtools__WEBPACK_IMPORTED_MODULE_5__[\"default\"].addStyle(_domtools__WEBPACK_IMPORTED_MODULE_5__[\"default\"].escapeID(theme.id), unescape(theme.css));\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"] && !reload) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${theme.name} v${theme.version} has been applied.`);\n};\n\nThemeModule.prototype.enable = function (name, reload = false) {\n return this.enableTheme(name, reload);\n};\n\nThemeModule.prototype.disableTheme = function (name, reload = false) {\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"][name] = false;\n this.saveThemeData();\n const theme = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][name];\n _domtools__WEBPACK_IMPORTED_MODULE_5__[\"default\"].removeStyle(_domtools__WEBPACK_IMPORTED_MODULE_5__[\"default\"].escapeID(theme.id));\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"] && !reload) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${theme.name} v${theme.version} has been disabled.`);\n};\n\nThemeModule.prototype.disable = function (name, reload = false) {\n return this.disableTheme(name, reload);\n};\n\nThemeModule.prototype.toggleTheme = function (theme) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"][theme]) this.disableTheme(theme);else this.enableTheme(theme);\n};\n\nThemeModule.prototype.toggle = function (name, reload = false) {\n return this.toggleTheme(name, reload);\n};\n\nThemeModule.prototype.loadTheme = function (filename) {\n const error = _contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].loadContent(filename, \"theme\");\n\n if (error) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-1\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showContentErrors({\n themes: [error]\n });\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${filename} could not be loaded. It may not have been loaded.`, {\n type: \"error\"\n });\n return _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"ContentManager\", `${filename} could not be loaded.`, error);\n }\n\n const theme = Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"]).find(p => p.filename == filename);\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].log(\"ContentManager\", `${theme.name} v${theme.version} was loaded.`);\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${theme.name} v${theme.version} was loaded.`, {\n type: \"success\"\n });\n _bdEvents__WEBPACK_IMPORTED_MODULE_3__[\"default\"].dispatch(\"theme-loaded\", theme.name);\n};\n\nThemeModule.prototype.unloadTheme = function (filenameOrName) {\n const bdtheme = Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"]).find(p => p.filename == filenameOrName) || _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][filenameOrName];\n if (!bdtheme) return;\n const theme = bdtheme.name;\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"][theme]) this.disableTheme(theme, true);\n const error = _contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].unloadContent(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][theme].filename, \"theme\");\n delete _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][theme];\n\n if (error) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-1\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showContentErrors({\n themes: [error]\n });\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${theme} could not be unloaded. It may have not been loaded yet.`, {\n type: \"error\"\n });\n return _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"ContentManager\", `${theme} could not be unloaded. It may have not been loaded yet.`, error);\n }\n\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].log(\"ContentManager\", `${theme} was unloaded.`);\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${theme} was unloaded.`, {\n type: \"success\"\n });\n _bdEvents__WEBPACK_IMPORTED_MODULE_3__[\"default\"].dispatch(\"theme-unloaded\", theme);\n};\n\nThemeModule.prototype.delete = function (filenameOrName) {\n const bdplugin = Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"]).find(p => p.filename == filenameOrName) || _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][filenameOrName];\n if (!bdplugin) return;\n this.unloadTheme(bdplugin.filename);\n\n const fullPath = __webpack_require__(/*! path */ \"path\").resolve(_contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].pluginsFolder, bdplugin.filename);\n\n __webpack_require__(/*! fs */ \"fs\").unlinkSync(fullPath);\n};\n\nThemeModule.prototype.reloadTheme = function (filenameOrName) {\n const bdtheme = Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"]).find(p => p.filename == filenameOrName) || _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][filenameOrName];\n if (!bdtheme) return this.loadTheme(filenameOrName);\n const theme = bdtheme.name;\n const error = _contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reloadContent(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][theme].filename, \"theme\");\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"][theme]) this.disableTheme(theme, true), this.enableTheme(theme, true);\n\n if (error) {\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-1\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showContentErrors({\n themes: [error]\n });\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${theme} could not be reloaded.`, {\n type: \"error\"\n });\n return _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].err(\"ContentManager\", `${theme} could not be reloaded.`, error);\n }\n\n _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].log(\"ContentManager\", `${theme} v${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][theme].version} was reloaded.`);\n if (_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-2\"]) _utils__WEBPACK_IMPORTED_MODULE_4__[\"default\"].showToast(`${theme} v${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][theme].version} was reloaded.`, {\n type: \"success\"\n });\n _bdEvents__WEBPACK_IMPORTED_MODULE_3__[\"default\"].dispatch(\"theme-reloaded\", theme);\n};\n\nThemeModule.prototype.reload = function (name) {\n return this.reloadTheme(name);\n};\n\nThemeModule.prototype.edit = function (filenameOrName) {\n const bdplugin = Object.values(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"]).find(p => p.filename == filenameOrName) || _0globals__WEBPACK_IMPORTED_MODULE_0__[\"bdthemes\"][filenameOrName];\n if (!bdplugin) return;\n\n const fullPath = __webpack_require__(/*! path */ \"path\").resolve(_contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].themesFolder, bdplugin.filename);\n\n __webpack_require__(/*! electron */ \"electron\").shell.openItem(`${fullPath}`);\n};\n\nThemeModule.prototype.updateThemeList = function () {\n const results = _contentManager__WEBPACK_IMPORTED_MODULE_1__[\"default\"].loadNewContent(\"theme\");\n\n for (const filename of results.added) this.loadTheme(filename);\n\n for (const name of results.removed) this.unloadTheme(name);\n};\n\nThemeModule.prototype.loadThemeData = function () {\n const saved = _dataStore__WEBPACK_IMPORTED_MODULE_2__[\"default\"].getSettingGroup(\"themes\");\n\n if (saved) {\n Object.assign(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"], saved);\n }\n};\n\nThemeModule.prototype.saveThemeData = function () {\n _dataStore__WEBPACK_IMPORTED_MODULE_2__[\"default\"].setSettingGroup(\"themes\", _0globals__WEBPACK_IMPORTED_MODULE_0__[\"themeCookie\"]);\n};\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (new ThemeModule());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/modules/themeModule.js.js","sources":["webpack://BetterDiscord/./src/modules/themeModule.js?8c47"],"sourcesContent":["import { bdthemeErrors, themeCookie, settingsCookie, bdthemes } from \"../0globals\";\nimport ContentManager from \"./contentManager\";\nimport DataStore from \"./dataStore\";\nimport BDEvents from \"./bdEvents\";\nimport Utils from \"./utils\";\nimport DOM from \"./domtools\";\n\nclass ThemeModule {\n  get folder() {\n    return ContentManager.themesFolder;\n  }\n\n}\n\nThemeModule.prototype.loadThemes = function () {\n  this.loadThemeData();\n  bdthemeErrors.splice(0, 0, ...ContentManager.loadThemes());\n  const themes = Object.keys(bdthemes);\n\n  for (let i = 0; i < themes.length; i++) {\n    const theme = bdthemes[themes[i]];\n    if (!themeCookie[theme.name]) themeCookie[theme.name] = false;\n    if (themeCookie[theme.name]) DOM.addStyle(DOM.escapeID(theme.id), unescape(theme.css));\n  }\n\n  for (const theme in themeCookie) {\n    if (!bdthemes[theme]) delete themeCookie[theme];\n  }\n\n  this.saveThemeData(); // if (settingsCookie[\"fork-ps-5\"]) ContentManager.watchContent(\"theme\");\n};\n\nThemeModule.prototype.enableTheme = function (name, reload = false) {\n  themeCookie[name] = true;\n  this.saveThemeData();\n  const theme = bdthemes[name];\n  DOM.addStyle(DOM.escapeID(theme.id), unescape(theme.css));\n  if (settingsCookie[\"fork-ps-2\"] && !reload) Utils.showToast(`${theme.name} v${theme.version} has been applied.`);\n};\n\nThemeModule.prototype.enable = function (name, reload = false) {\n  return this.enableTheme(name, reload);\n};\n\nThemeModule.prototype.disableTheme = function (name, reload = false) {\n  themeCookie[name] = false;\n  this.saveThemeData();\n  const theme = bdthemes[name];\n  DOM.removeStyle(DOM.escapeID(theme.id));\n  if (settingsCookie[\"fork-ps-2\"] && !reload) Utils.showToast(`${theme.name} v${theme.version} has been disabled.`);\n};\n\nThemeModule.prototype.disable = function (name, reload = false) {\n  return this.disableTheme(name, reload);\n};\n\nThemeModule.prototype.toggleTheme = function (theme) {\n  if (themeCookie[theme]) this.disableTheme(theme);else this.enableTheme(theme);\n};\n\nThemeModule.prototype.toggle = function (name, reload = false) {\n  return this.toggleTheme(name, reload);\n};\n\nThemeModule.prototype.loadTheme = function (filename) {\n  const error = ContentManager.loadContent(filename, \"theme\");\n\n  if (error) {\n    if (settingsCookie[\"fork-ps-1\"]) Utils.showContentErrors({\n      themes: [error]\n    });\n    if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${filename} could not be loaded. It may not have been loaded.`, {\n      type: \"error\"\n    });\n    return Utils.err(\"ContentManager\", `${filename} could not be loaded.`, error);\n  }\n\n  const theme = Object.values(bdthemes).find(p => p.filename == filename);\n  Utils.log(\"ContentManager\", `${theme.name} v${theme.version} was loaded.`);\n  if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${theme.name} v${theme.version} was loaded.`, {\n    type: \"success\"\n  });\n  BDEvents.dispatch(\"theme-loaded\", theme.name);\n};\n\nThemeModule.prototype.unloadTheme = function (filenameOrName) {\n  const bdtheme = Object.values(bdthemes).find(p => p.filename == filenameOrName) || bdthemes[filenameOrName];\n  if (!bdtheme) return;\n  const theme = bdtheme.name;\n  if (themeCookie[theme]) this.disableTheme(theme, true);\n  const error = ContentManager.unloadContent(bdthemes[theme].filename, \"theme\");\n  delete bdthemes[theme];\n\n  if (error) {\n    if (settingsCookie[\"fork-ps-1\"]) Utils.showContentErrors({\n      themes: [error]\n    });\n    if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${theme} could not be unloaded. It may have not been loaded yet.`, {\n      type: \"error\"\n    });\n    return Utils.err(\"ContentManager\", `${theme} could not be unloaded. It may have not been loaded yet.`, error);\n  }\n\n  Utils.log(\"ContentManager\", `${theme} was unloaded.`);\n  if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${theme} was unloaded.`, {\n    type: \"success\"\n  });\n  BDEvents.dispatch(\"theme-unloaded\", theme);\n};\n\nThemeModule.prototype.delete = function (filenameOrName) {\n  const bdplugin = Object.values(bdthemes).find(p => p.filename == filenameOrName) || bdthemes[filenameOrName];\n  if (!bdplugin) return;\n  this.unloadTheme(bdplugin.filename);\n\n  const fullPath = require(\"path\").resolve(ContentManager.pluginsFolder, bdplugin.filename);\n\n  require(\"fs\").unlinkSync(fullPath);\n};\n\nThemeModule.prototype.reloadTheme = function (filenameOrName) {\n  const bdtheme = Object.values(bdthemes).find(p => p.filename == filenameOrName) || bdthemes[filenameOrName];\n  if (!bdtheme) return this.loadTheme(filenameOrName);\n  const theme = bdtheme.name;\n  const error = ContentManager.reloadContent(bdthemes[theme].filename, \"theme\");\n  if (themeCookie[theme]) this.disableTheme(theme, true), this.enableTheme(theme, true);\n\n  if (error) {\n    if (settingsCookie[\"fork-ps-1\"]) Utils.showContentErrors({\n      themes: [error]\n    });\n    if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${theme} could not be reloaded.`, {\n      type: \"error\"\n    });\n    return Utils.err(\"ContentManager\", `${theme} could not be reloaded.`, error);\n  }\n\n  Utils.log(\"ContentManager\", `${theme} v${bdthemes[theme].version} was reloaded.`);\n  if (settingsCookie[\"fork-ps-2\"]) Utils.showToast(`${theme} v${bdthemes[theme].version} was reloaded.`, {\n    type: \"success\"\n  });\n  BDEvents.dispatch(\"theme-reloaded\", theme);\n};\n\nThemeModule.prototype.reload = function (name) {\n  return this.reloadTheme(name);\n};\n\nThemeModule.prototype.edit = function (filenameOrName) {\n  const bdplugin = Object.values(bdthemes).find(p => p.filename == filenameOrName) || bdthemes[filenameOrName];\n  if (!bdplugin) return;\n\n  const fullPath = require(\"path\").resolve(ContentManager.themesFolder, bdplugin.filename);\n\n  require(\"electron\").shell.openItem(`${fullPath}`);\n};\n\nThemeModule.prototype.updateThemeList = function () {\n  const results = ContentManager.loadNewContent(\"theme\");\n\n  for (const filename of results.added) this.loadTheme(filename);\n\n  for (const name of results.removed) this.unloadTheme(name);\n};\n\nThemeModule.prototype.loadThemeData = function () {\n  const saved = DataStore.getSettingGroup(\"themes\");\n\n  if (saved) {\n    Object.assign(themeCookie, saved);\n  }\n};\n\nThemeModule.prototype.saveThemeData = function () {\n  DataStore.setSettingGroup(\"themes\", themeCookie);\n};\n\nexport default new ThemeModule();"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/modules/themeModule.js\n"); + +/***/ }), + +/***/ "./src/modules/utils.js": +/*!******************************!*\ + !*** ./src/modules/utils.js ***! + \******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Utils; });\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _webpackModules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./webpackModules */ \"./src/modules/webpackModules.js\");\n/* harmony import */ var _v2__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _domtools__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./domtools */ \"./src/modules/domtools.js\");\n\n\n\n\nclass Utils {\n /** Document/window width */\n static get screenWidth() {\n return Math.max(document.documentElement.clientWidth, window.innerWidth || 0);\n }\n /** Document/window height */\n\n\n static get screenHeight() {\n return Math.max(document.documentElement.clientHeight, window.innerHeight || 0);\n }\n\n static get WindowConfigFile() {\n return this._windowConfigFile = null;\n }\n\n static getAllWindowPreferences() {\n return {\n transparent: _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-wp-1\"] || _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"].transparency,\n frame: _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"].frame\n };\n }\n\n static getWindowPreference(key) {\n if (key === \"transparent\") return _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-wp-1\"] || _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"].transparency;\n if (key === \"frame\") return _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"].frame;\n return null;\n }\n\n static setWindowPreference(key, value) {\n if (key === \"transparent\") return _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-wp-1\"] = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"].transparency = value;\n if (key === \"frame\") return _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"].frame = value;\n return null;\n }\n\n static stripBOM(content) {\n if (content.charCodeAt(0) === 0xFEFF) {\n content = content.slice(1);\n }\n\n return content;\n }\n\n static getTextArea() {\n return _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].query(\".\" + BDModules.get(e => e.channelTextArea && e.titleWrapper)[0].channelTextArea.split(\" \")[0] + \" textarea\");\n }\n\n static insertText(textarea, text) {\n textarea.focus();\n textarea.selectionStart = 0;\n textarea.selectionEnd = textarea.value.length;\n document.execCommand(\"insertText\", false, text);\n }\n\n static escapeID(id) {\n return id.replace(/^[^a-z]+|[^\\w-]+/gi, \"-\");\n }\n\n static log(moduleName, message) {\n console.log(`%c[BandagedBD]%c [${moduleName}]%c ${message}`, \"color: #3a71c1; font-weight: 700;\", \"color: #3a71c1;\", \"\");\n }\n\n static warn(moduleName, message) {\n console.warn(`%c[BandagedBD]%c [${moduleName}]%c ${message}`, \"color: #E8A400; font-weight: 700;\", \"color: #E8A400;\", \"\");\n }\n\n static err(moduleName, message, error) {\n console.log(`%c[BandagedBD]%c [${moduleName}]%c ${message}`, \"color: red; font-weight: 700;\", \"color: red;\", \"\");\n\n if (error) {\n console.groupCollapsed(\"%cError: \" + error.message, \"color: red;\");\n console.error(error.stack);\n console.groupEnd();\n }\n }\n\n static escape(s) {\n return s.replace(/[-/\\\\^$*+?.()|[\\]{}]/g, \"\\\\$&\");\n }\n\n static testJSON(data) {\n try {\n return JSON.parse(data);\n } catch (err) {\n return false;\n }\n }\n\n static isEmpty(obj) {\n if (obj == null || obj == undefined || obj == \"\") return true;\n if (typeof obj !== \"object\") return false;\n if (Array.isArray(obj)) return obj.length == 0;\n\n for (const key in obj) {\n if (obj.hasOwnProperty(key)) return false;\n }\n\n return true;\n }\n\n static suppressErrors(method, message) {\n return (...params) => {\n try {\n return method(...params);\n } catch (e) {\n this.err(\"SuppressedError\", \"Error occurred in \" + message, e);\n }\n };\n }\n\n static monkeyPatch(what, methodName, options) {\n const {\n before,\n after,\n instead,\n once = false,\n silent = false,\n force = false\n } = options;\n const displayName = options.displayName || what.displayName || what[methodName].displayName || what.name || what.constructor.displayName || what.constructor.name;\n if (!silent) console.log(\"patch\", methodName, \"of\", displayName); // eslint-disable-line no-console\n\n if (!what[methodName]) {\n if (force) what[methodName] = function () {};else return console.error(methodName, \"does not exist for\", displayName); // eslint-disable-line no-console\n }\n\n const origMethod = what[methodName];\n\n const cancel = () => {\n if (!silent) console.log(\"unpatch\", methodName, \"of\", displayName); // eslint-disable-line no-console\n\n what[methodName] = origMethod;\n };\n\n what[methodName] = function () {\n const data = {\n thisObject: this,\n methodArguments: arguments,\n cancelPatch: cancel,\n originalMethod: origMethod,\n callOriginalMethod: () => data.returnValue = data.originalMethod.apply(data.thisObject, data.methodArguments)\n };\n\n if (instead) {\n const tempRet = Utils.suppressErrors(instead, \"`instead` callback of \" + what[methodName].displayName)(data);\n if (tempRet !== undefined) data.returnValue = tempRet;\n } else {\n if (before) Utils.suppressErrors(before, \"`before` callback of \" + what[methodName].displayName)(data);\n data.callOriginalMethod();\n if (after) Utils.suppressErrors(after, \"`after` callback of \" + what[methodName].displayName)(data);\n }\n\n if (once) cancel();\n return data.returnValue;\n };\n\n Object.assign(what[methodName], origMethod);\n what[methodName].__monkeyPatched = true;\n what[methodName].displayName = displayName;\n\n if (!what[methodName].__originalMethod) {\n what[methodName].__originalMethod = origMethod;\n\n what[methodName].toString = function () {\n return origMethod.toString();\n };\n }\n\n return cancel;\n }\n\n static onRemoved(node, callback) {\n const observer = new MutationObserver(mutations => {\n for (let m = 0; m < mutations.length; m++) {\n const mutation = mutations[m];\n const nodes = Array.from(mutation.removedNodes);\n const directMatch = nodes.indexOf(node) > -1;\n const parentMatch = nodes.some(parent => parent.contains(node));\n\n if (directMatch || parentMatch) {\n observer.disconnect();\n callback();\n }\n }\n });\n observer.observe(document.body, {\n subtree: true,\n childList: true\n });\n }\n\n static getNestedProp(obj, path) {\n return path.split(/\\s?\\.\\s?/).reduce(function (obj, prop) {\n return obj && obj[prop];\n }, obj);\n }\n /**\r\n * This shows a toast similar to android towards the bottom of the screen.\r\n *\r\n * @param {string} content The string to show in the toast.\r\n * @param {object} options Options object. Optional parameter.\r\n * @param {string} options.type Changes the type of the toast stylistically and semantically. Choices: \"\", \"info\", \"success\", \"danger\"/\"error\", \"warning\"/\"warn\". Default: \"\"\r\n * @param {boolean} options.icon Determines whether the icon should show corresponding to the type. A toast without type will always have no icon. Default: true\r\n * @param {number} options.timeout Adjusts the time (in ms) the toast should be shown for before disappearing automatically. Default: 3000\r\n */\n\n\n static showToast(content, options = {}) {\n if (!document.querySelector(\".bd-toasts\")) {\n const container = document.querySelector(\".\" + BDModules.get(e => e.sidebar && e.hasNotice)[0].sidebar.split(\" \")[9] + \" + div\") || null;\n const memberlist = container ? container.querySelector(\".\" + BDModules.get(e => e.membersWrap)[0].membersWrap) : null;\n const form = container ? container.querySelector(\"form\") : null;\n const left = container ? container.getBoundingClientRect().left : 310;\n const right = memberlist ? memberlist.getBoundingClientRect().left : 0;\n const width = right ? right - container.getBoundingClientRect().left : Utils.screenWidth - left - 240;\n const bottom = form ? form.offsetHeight : 80;\n const toastWrapper = document.createElement(\"div\");\n toastWrapper.classList.add(\"bd-toasts\");\n toastWrapper.style.setProperty(\"left\", left + \"px\");\n toastWrapper.style.setProperty(\"width\", width + \"px\");\n toastWrapper.style.setProperty(\"bottom\", bottom + \"px\");\n document.querySelector(\"#app-mount\").appendChild(toastWrapper);\n }\n\n const {\n type = \"\",\n icon = true,\n timeout = 3000\n } = options;\n const toastElem = document.createElement(\"div\");\n toastElem.classList.add(\"bd-toast\");\n if (type) toastElem.classList.add(\"toast-\" + type);\n if (type && icon) toastElem.classList.add(\"icon\");\n toastElem.innerText = content;\n document.querySelector(\".bd-toasts\").appendChild(toastElem);\n setTimeout(() => {\n toastElem.classList.add(\"closing\");\n setTimeout(() => {\n toastElem.remove();\n if (!document.querySelectorAll(\".bd-toasts .bd-toast\").length) document.querySelector(\".bd-toasts\").remove();\n }, 300);\n }, timeout);\n }\n\n static alert(title, content) {\n let modalModule = BDModules.get(e => e.modal && e.inner && !e.hideOnFullscreen)[0];\n let headerModule = BDModules.get(e => e.header && e.responsiveWidthMobile && e.hideOnFullscreen)[0];\n let footer2Module = BDModules.get(e => e.header && e.responsiveWidthMobile && e.focusLock)[0];\n const modal = _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].createElement(`
\n
e.backdrop && e.backdropWithLayer)[0].backdrop}\">
\n
\n
\n
\n
${title}
\n
\n
\n
\n
\n ${content}\n
\n
\n
\n
\n \n
\n
\n
\n
`);\n modal.querySelector(\".footer button\").addEventListener(\"click\", () => {\n _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].addClass(modal, \"closing\");\n setTimeout(() => {\n modal.remove();\n }, 300);\n });\n modal.querySelector(\".bd-backdrop\").addEventListener(\"click\", () => {\n _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].addClass(modal, \"closing\");\n setTimeout(() => {\n modal.remove();\n }, 300);\n });\n _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].query(\"#app-mount\").append(modal);\n }\n\n static showContentErrors({\n plugins: pluginErrors = [],\n themes: themeErrors = []\n }) {\n if (!pluginErrors || !themeErrors) return;\n if (!pluginErrors.length && !themeErrors.length) return;\n let modalModule = BDModules.get(e => e.modal && e.inner && !e.hideOnFullscreen)[0];\n let headerModule = BDModules.get(e => e.header && e.responsiveWidthMobile && e.hideOnFullscreen)[0];\n let footer2Module = BDModules.get(e => e.header && e.responsiveWidthMobile && e.focusLock)[0];\n const modal = _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].createElement(`
\n
e.backdrop && e.backdropWithLayer)[0].backdrop}\">
\n
\n
\n
Content Errors
\n
\n
\n
\n
Plugins
\n
Themes
\n
\n
\n
\n
Name
\n
Message
\n
Error
\n
\n
\n
\n \n
\n
\n
\n
\n \n
\n
\n
\n
`);\n\n function generateTab(errors) {\n const container = _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].createElement(`
`);\n\n for (const err of errors) {\n const error = _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].createElement(`
\n
${err.name ? err.name : err.file}
\n
${err.message}
\n \n
`);\n container.append(error);\n\n if (err.error) {\n error.querySelectorAll(\"a\").forEach(el => el.addEventListener(\"click\", e => {\n e.preventDefault();\n Utils.err(\"ContentManager\", `Error details for ${err.name ? err.name : err.file}.`, err.error);\n }));\n }\n }\n\n return container;\n }\n\n const tabs = [generateTab(pluginErrors), generateTab(themeErrors)];\n modal.querySelectorAll(\".tab-bar-item\").forEach(el => el.addEventListener(\"click\", e => {\n e.preventDefault();\n const selected = modal.querySelector(\".tab-bar-item.selected\");\n if (selected) _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].removeClass(selected, \"selected\");\n _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].addClass(e.target, \"selected\");\n const scroller = modal.querySelector(\".scroller\");\n scroller.innerHTML = \"\";\n scroller.append(tabs[_domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].index(e.target)]);\n }));\n modal.querySelector(\".footer button\").addEventListener(\"click\", () => {\n _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].addClass(modal, \"closing\");\n setTimeout(() => {\n modal.remove();\n }, 300);\n });\n modal.querySelector(\".bd-backdrop\").addEventListener(\"click\", () => {\n _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].addClass(modal, \"closing\");\n setTimeout(() => {\n modal.remove();\n }, 300);\n });\n _domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].query(\"#app-mount\").append(modal);\n if (pluginErrors.length) modal.querySelector(\".tab-bar-item\").click();else modal.querySelectorAll(\".tab-bar-item\")[1].click();\n }\n\n static showChangelogModal(options = {}) {\n const ModalStack = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].findByProps(\"push\", \"update\", \"pop\", \"popWithKey\");\n const ChangelogClasses = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].findByProps(\"fixed\", \"improved\");\n const TextElement = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].findByDisplayName(\"Text\");\n const FlexChild = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].findByProps(\"Child\");\n const Titles = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].findByProps(\"Tags\", \"default\");\n const Changelog = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].find(m => m.defaultProps && m.defaultProps.selectable == false);\n const MarkdownParser = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].findByProps(\"defaultRules\", \"parse\");\n if (!Changelog || !ModalStack || !ChangelogClasses || !TextElement || !FlexChild || !Titles || !MarkdownParser) return;\n const {\n image = \"https://repository-images.githubusercontent.com/105473537/957b5480-7c26-11e9-8401-50fa820cbae5\",\n description = \"\",\n changes = [],\n title = \"BandagedBD\",\n subtitle = `v${_0globals__WEBPACK_IMPORTED_MODULE_0__[\"bbdVersion\"]}`,\n footer\n } = options;\n const ce = _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement;\n const changelogItems = [ce(\"img\", {\n src: image\n })];\n if (description) changelogItems.push(ce(\"p\", null, MarkdownParser.parse(description)));\n\n for (let c = 0; c < changes.length; c++) {\n const entry = changes[c];\n const type = ChangelogClasses[entry.type] ? ChangelogClasses[entry.type] : ChangelogClasses.added;\n const margin = c == 0 ? ChangelogClasses.marginTop : \"\";\n changelogItems.push(ce(\"h1\", {\n className: `${type} ${margin}`\n }, entry.title));\n const list = ce(\"ul\", null, entry.items.map(i => ce(\"li\", null, MarkdownParser.parse(i))));\n changelogItems.push(list);\n }\n\n const renderHeader = function () {\n return ce(FlexChild.Child, {\n grow: 1,\n shrink: 1\n }, ce(Titles.default, {\n tag: Titles.Tags.H4\n }, title), ce(TextElement, {\n size: TextElement.Sizes.SMALL,\n color: TextElement.Colors.STANDARD,\n className: ChangelogClasses.date\n }, subtitle));\n };\n\n const renderFooter = () => {\n const Anchor = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].find(m => m.displayName == \"Anchor\");\n const AnchorClasses = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].findByProps(\"anchorUnderlineOnHover\") || {\n anchor: \"anchor-3Z-8Bb\",\n anchorUnderlineOnHover: \"anchorUnderlineOnHover-2ESHQB\"\n };\n\n const joinSupportServer = click => {\n click.preventDefault();\n click.stopPropagation();\n ModalStack.pop();\n _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].joinBD2();\n };\n\n const supportLink = Anchor ? ce(Anchor, {\n onClick: joinSupportServer\n }, \"Join our Discord Server.\") : ce(\"a\", {\n className: `${AnchorClasses.anchor} ${AnchorClasses.anchorUnderlineOnHover}`,\n onClick: joinSupportServer\n }, \"Join our Discord Server.\");\n const defaultFooter = ce(TextElement, {\n size: TextElement.Sizes.SMALL,\n color: TextElement.Colors.STANDARD\n }, \"Need support? \", supportLink);\n return ce(FlexChild.Child, {\n grow: 1,\n shrink: 1\n }, footer ? footer : defaultFooter);\n };\n\n return ModalStack.push(function (props) {\n return ce(Changelog, Object.assign({\n className: ChangelogClasses.container,\n selectable: true,\n onScroll: _ => _,\n onClose: _ => _,\n renderHeader: renderHeader,\n renderFooter: renderFooter,\n children: changelogItems\n }, props));\n });\n }\n /**\r\n * Shows a generic but very customizable confirmation modal with optional confirm and cancel callbacks.\r\n * @param {string} title - title of the modal\r\n * @param {(string|ReactElement|Array)} children - a single or mixed array of react elements and strings. Every string is wrapped in Discord's `Markdown` component so strings will show and render properly.\r\n * @param {object} [options] - options to modify the modal\r\n * @param {boolean} [options.danger=false] - whether the main button should be red or not\r\n * @param {string} [options.confirmText=Okay] - text for the confirmation/submit button\r\n * @param {string} [options.cancelText=Cancel] - text for the cancel button\r\n * @param {callable} [options.onConfirm=NOOP] - callback to occur when clicking the submit button\r\n * @param {callable} [options.onCancel=NOOP] - callback to occur when clicking the cancel button\r\n * @param {string} [options.key] - key used to identify the modal. If not provided, one is generated and returned\r\n * @returns {string} - the key used for this modal\r\n */\n\n\n static showConfirmationModal(title, content, options = {}) {\n const ModalStack = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].findByProps(\"push\", \"update\", \"pop\", \"popWithKey\");\n const Markdown = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].findByDisplayName(\"Markdown\");\n const ConfirmationModal = _webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].find(m => m.defaultProps && m.key && m.key() == \"confirm-modal\");\n if (!ModalStack || !ConfirmationModal || !Markdown) return Utils.alert(title, content);\n\n const emptyFunction = () => {};\n\n const {\n onConfirm = emptyFunction,\n onCancel = emptyFunction,\n confirmText = \"Okay\",\n cancelText = \"Cancel\",\n danger = false,\n key = undefined\n } = options;\n if (!Array.isArray(content)) content = [content];\n content = content.map(c => typeof c === \"string\" ? _v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].React.createElement(Markdown, null, c) : c);\n return ModalStack.push(ConfirmationModal, {\n header: title,\n children: content,\n red: danger,\n confirmText: confirmText,\n cancelText: cancelText,\n onConfirm: onConfirm,\n onCancel: onCancel\n }, key);\n }\n\n}\nUtils.showToast = Utils.suppressErrors(Utils.showToast, \"Could not show toast.\");//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/modules/utils.js.js","sources":["webpack://BetterDiscord/./src/modules/utils.js?c0f7"],"sourcesContent":["import { bbdVersion, settingsCookie } from \"../0globals\";\nimport WebpackModules from \"./webpackModules\";\nimport BDV2 from \"./v2\";\nimport DOM from \"./domtools\";\nexport default class Utils {\n  /** Document/window width */\n  static get screenWidth() {\n    return Math.max(document.documentElement.clientWidth, window.innerWidth || 0);\n  }\n  /** Document/window height */\n\n\n  static get screenHeight() {\n    return Math.max(document.documentElement.clientHeight, window.innerHeight || 0);\n  }\n\n  static get WindowConfigFile() {\n    return this._windowConfigFile = null;\n  }\n\n  static getAllWindowPreferences() {\n    return {\n      transparent: settingsCookie[\"fork-wp-1\"] || settingsCookie.transparency,\n      frame: settingsCookie.frame\n    };\n  }\n\n  static getWindowPreference(key) {\n    if (key === \"transparent\") return settingsCookie[\"fork-wp-1\"] || settingsCookie.transparency;\n    if (key === \"frame\") return settingsCookie.frame;\n    return null;\n  }\n\n  static setWindowPreference(key, value) {\n    if (key === \"transparent\") return settingsCookie[\"fork-wp-1\"] = settingsCookie.transparency = value;\n    if (key === \"frame\") return settingsCookie.frame = value;\n    return null;\n  }\n\n  static stripBOM(content) {\n    if (content.charCodeAt(0) === 0xFEFF) {\n      content = content.slice(1);\n    }\n\n    return content;\n  }\n\n  static getTextArea() {\n    return DOM.query(\".\" + BDModules.get(e => e.channelTextArea && e.titleWrapper)[0].channelTextArea.split(\" \")[0] + \" textarea\");\n  }\n\n  static insertText(textarea, text) {\n    textarea.focus();\n    textarea.selectionStart = 0;\n    textarea.selectionEnd = textarea.value.length;\n    document.execCommand(\"insertText\", false, text);\n  }\n\n  static escapeID(id) {\n    return id.replace(/^[^a-z]+|[^\\w-]+/gi, \"-\");\n  }\n\n  static log(moduleName, message) {\n    console.log(`%c[BandagedBD]%c [${moduleName}]%c ${message}`, \"color: #3a71c1; font-weight: 700;\", \"color: #3a71c1;\", \"\");\n  }\n\n  static warn(moduleName, message) {\n    console.warn(`%c[BandagedBD]%c [${moduleName}]%c ${message}`, \"color: #E8A400; font-weight: 700;\", \"color: #E8A400;\", \"\");\n  }\n\n  static err(moduleName, message, error) {\n    console.log(`%c[BandagedBD]%c [${moduleName}]%c ${message}`, \"color: red; font-weight: 700;\", \"color: red;\", \"\");\n\n    if (error) {\n      console.groupCollapsed(\"%cError: \" + error.message, \"color: red;\");\n      console.error(error.stack);\n      console.groupEnd();\n    }\n  }\n\n  static escape(s) {\n    return s.replace(/[-/\\\\^$*+?.()|[\\]{}]/g, \"\\\\$&\");\n  }\n\n  static testJSON(data) {\n    try {\n      return JSON.parse(data);\n    } catch (err) {\n      return false;\n    }\n  }\n\n  static isEmpty(obj) {\n    if (obj == null || obj == undefined || obj == \"\") return true;\n    if (typeof obj !== \"object\") return false;\n    if (Array.isArray(obj)) return obj.length == 0;\n\n    for (const key in obj) {\n      if (obj.hasOwnProperty(key)) return false;\n    }\n\n    return true;\n  }\n\n  static suppressErrors(method, message) {\n    return (...params) => {\n      try {\n        return method(...params);\n      } catch (e) {\n        this.err(\"SuppressedError\", \"Error occurred in \" + message, e);\n      }\n    };\n  }\n\n  static monkeyPatch(what, methodName, options) {\n    const {\n      before,\n      after,\n      instead,\n      once = false,\n      silent = false,\n      force = false\n    } = options;\n    const displayName = options.displayName || what.displayName || what[methodName].displayName || what.name || what.constructor.displayName || what.constructor.name;\n    if (!silent) console.log(\"patch\", methodName, \"of\", displayName); // eslint-disable-line no-console\n\n    if (!what[methodName]) {\n      if (force) what[methodName] = function () {};else return console.error(methodName, \"does not exist for\", displayName); // eslint-disable-line no-console\n    }\n\n    const origMethod = what[methodName];\n\n    const cancel = () => {\n      if (!silent) console.log(\"unpatch\", methodName, \"of\", displayName); // eslint-disable-line no-console\n\n      what[methodName] = origMethod;\n    };\n\n    what[methodName] = function () {\n      const data = {\n        thisObject: this,\n        methodArguments: arguments,\n        cancelPatch: cancel,\n        originalMethod: origMethod,\n        callOriginalMethod: () => data.returnValue = data.originalMethod.apply(data.thisObject, data.methodArguments)\n      };\n\n      if (instead) {\n        const tempRet = Utils.suppressErrors(instead, \"`instead` callback of \" + what[methodName].displayName)(data);\n        if (tempRet !== undefined) data.returnValue = tempRet;\n      } else {\n        if (before) Utils.suppressErrors(before, \"`before` callback of \" + what[methodName].displayName)(data);\n        data.callOriginalMethod();\n        if (after) Utils.suppressErrors(after, \"`after` callback of \" + what[methodName].displayName)(data);\n      }\n\n      if (once) cancel();\n      return data.returnValue;\n    };\n\n    Object.assign(what[methodName], origMethod);\n    what[methodName].__monkeyPatched = true;\n    what[methodName].displayName = displayName;\n\n    if (!what[methodName].__originalMethod) {\n      what[methodName].__originalMethod = origMethod;\n\n      what[methodName].toString = function () {\n        return origMethod.toString();\n      };\n    }\n\n    return cancel;\n  }\n\n  static onRemoved(node, callback) {\n    const observer = new MutationObserver(mutations => {\n      for (let m = 0; m < mutations.length; m++) {\n        const mutation = mutations[m];\n        const nodes = Array.from(mutation.removedNodes);\n        const directMatch = nodes.indexOf(node) > -1;\n        const parentMatch = nodes.some(parent => parent.contains(node));\n\n        if (directMatch || parentMatch) {\n          observer.disconnect();\n          callback();\n        }\n      }\n    });\n    observer.observe(document.body, {\n      subtree: true,\n      childList: true\n    });\n  }\n\n  static getNestedProp(obj, path) {\n    return path.split(/\\s?\\.\\s?/).reduce(function (obj, prop) {\n      return obj && obj[prop];\n    }, obj);\n  }\n  /**\r\n   * This shows a toast similar to android towards the bottom of the screen.\r\n   *\r\n   * @param {string} content The string to show in the toast.\r\n   * @param {object} options Options object. Optional parameter.\r\n   * @param {string} options.type Changes the type of the toast stylistically and semantically. Choices: \"\", \"info\", \"success\", \"danger\"/\"error\", \"warning\"/\"warn\". Default: \"\"\r\n   * @param {boolean} options.icon Determines whether the icon should show corresponding to the type. A toast without type will always have no icon. Default: true\r\n   * @param {number} options.timeout Adjusts the time (in ms) the toast should be shown for before disappearing automatically. Default: 3000\r\n   */\n\n\n  static showToast(content, options = {}) {\n    if (!document.querySelector(\".bd-toasts\")) {\n      const container = document.querySelector(\".\" + BDModules.get(e => e.sidebar && e.hasNotice)[0].sidebar.split(\" \")[9] + \" + div\") || null;\n      const memberlist = container ? container.querySelector(\".\" + BDModules.get(e => e.membersWrap)[0].membersWrap) : null;\n      const form = container ? container.querySelector(\"form\") : null;\n      const left = container ? container.getBoundingClientRect().left : 310;\n      const right = memberlist ? memberlist.getBoundingClientRect().left : 0;\n      const width = right ? right - container.getBoundingClientRect().left : Utils.screenWidth - left - 240;\n      const bottom = form ? form.offsetHeight : 80;\n      const toastWrapper = document.createElement(\"div\");\n      toastWrapper.classList.add(\"bd-toasts\");\n      toastWrapper.style.setProperty(\"left\", left + \"px\");\n      toastWrapper.style.setProperty(\"width\", width + \"px\");\n      toastWrapper.style.setProperty(\"bottom\", bottom + \"px\");\n      document.querySelector(\"#app-mount\").appendChild(toastWrapper);\n    }\n\n    const {\n      type = \"\",\n      icon = true,\n      timeout = 3000\n    } = options;\n    const toastElem = document.createElement(\"div\");\n    toastElem.classList.add(\"bd-toast\");\n    if (type) toastElem.classList.add(\"toast-\" + type);\n    if (type && icon) toastElem.classList.add(\"icon\");\n    toastElem.innerText = content;\n    document.querySelector(\".bd-toasts\").appendChild(toastElem);\n    setTimeout(() => {\n      toastElem.classList.add(\"closing\");\n      setTimeout(() => {\n        toastElem.remove();\n        if (!document.querySelectorAll(\".bd-toasts .bd-toast\").length) document.querySelector(\".bd-toasts\").remove();\n      }, 300);\n    }, timeout);\n  }\n\n  static alert(title, content) {\n    let modalModule = BDModules.get(e => e.modal && e.inner && !e.hideOnFullscreen)[0];\n    let headerModule = BDModules.get(e => e.header && e.responsiveWidthMobile && e.hideOnFullscreen)[0];\n    let footer2Module = BDModules.get(e => e.header && e.responsiveWidthMobile && e.focusLock)[0];\n    const modal = DOM.createElement(`<div class=\"bd-modal-wrapper theme-dark\">\n                        <div class=\"bd-backdrop ${BDModules.get(e => e.backdrop && e.backdropWithLayer)[0].backdrop}\"></div>\n                        <div class=\"bd-modal ${modalModule.modal}\">\n                            <div class=\"bd-modal-inner ${modalModule.inner}\">\n                                <div class=\"header ${headerModule.header}\">\n                                    <div class=\"title\">${title}</div>\n                                </div>\n                                <div class=\"bd-modal-body\">\n                                    <div class=\"scroller-wrap fade\">\n                                        <div class=\"scroller\">\n                                            ${content}\n                                        </div>\n                                    </div>\n                                </div>\n                                <div class=\"footer ${headerModule.footer} ${footer2Module.footer}\">\n                                    <button type=\"button\">Okay</button>\n                                </div>\n                            </div>\n                        </div>\n                    </div>`);\n    modal.querySelector(\".footer button\").addEventListener(\"click\", () => {\n      DOM.addClass(modal, \"closing\");\n      setTimeout(() => {\n        modal.remove();\n      }, 300);\n    });\n    modal.querySelector(\".bd-backdrop\").addEventListener(\"click\", () => {\n      DOM.addClass(modal, \"closing\");\n      setTimeout(() => {\n        modal.remove();\n      }, 300);\n    });\n    DOM.query(\"#app-mount\").append(modal);\n  }\n\n  static showContentErrors({\n    plugins: pluginErrors = [],\n    themes: themeErrors = []\n  }) {\n    if (!pluginErrors || !themeErrors) return;\n    if (!pluginErrors.length && !themeErrors.length) return;\n    let modalModule = BDModules.get(e => e.modal && e.inner && !e.hideOnFullscreen)[0];\n    let headerModule = BDModules.get(e => e.header && e.responsiveWidthMobile && e.hideOnFullscreen)[0];\n    let footer2Module = BDModules.get(e => e.header && e.responsiveWidthMobile && e.focusLock)[0];\n    const modal = DOM.createElement(`<div class=\"bd-modal-wrapper theme-dark\">\n                        <div class=\"bd-backdrop ${BDModules.get(e => e.backdrop && e.backdropWithLayer)[0].backdrop}\"></div>\n                        <div class=\"bd-modal bd-content-modal ${modalModule.modal}\">\n                            <div class=\"bd-modal-inner ${modalModule.inner}\">\n                                <div class=\"header ${headerModule.header}\"><div class=\"title\">Content Errors</div></div>\n                                <div class=\"bd-modal-body\">\n                                    <div class=\"tab-bar-container\">\n                                        <div class=\"tab-bar TOP\">\n                                            <div class=\"tab-bar-item\">Plugins</div>\n                                            <div class=\"tab-bar-item\">Themes</div>\n                                        </div>\n                                    </div>\n                                    <div class=\"table-header\">\n                                        <div class=\"table-column column-name\">Name</div>\n                                        <div class=\"table-column column-message\">Message</div>\n                                        <div class=\"table-column column-error\">Error</div>\n                                    </div>\n                                    <div class=\"scroller-wrap fade\">\n                                        <div class=\"scroller\">\n    \n                                        </div>\n                                    </div>\n                                </div>\n                                <div class=\"footer ${headerModule.footer} ${footer2Module.footer}\">\n                                    <button type=\"button\">Okay</button>\n                                </div>\n                            </div>\n                        </div>\n                    </div>`);\n\n    function generateTab(errors) {\n      const container = DOM.createElement(`<div class=\"errors\">`);\n\n      for (const err of errors) {\n        const error = DOM.createElement(`<div class=\"error\">\n                                    <div class=\"table-column column-name\">${err.name ? err.name : err.file}</div>\n                                    <div class=\"table-column column-message\">${err.message}</div>\n                                    <div class=\"table-column column-error\"><a class=\"error-link\" href=\"\">${err.error ? err.error.message : \"\"}</a></div>\n                                </div>`);\n        container.append(error);\n\n        if (err.error) {\n          error.querySelectorAll(\"a\").forEach(el => el.addEventListener(\"click\", e => {\n            e.preventDefault();\n            Utils.err(\"ContentManager\", `Error details for ${err.name ? err.name : err.file}.`, err.error);\n          }));\n        }\n      }\n\n      return container;\n    }\n\n    const tabs = [generateTab(pluginErrors), generateTab(themeErrors)];\n    modal.querySelectorAll(\".tab-bar-item\").forEach(el => el.addEventListener(\"click\", e => {\n      e.preventDefault();\n      const selected = modal.querySelector(\".tab-bar-item.selected\");\n      if (selected) DOM.removeClass(selected, \"selected\");\n      DOM.addClass(e.target, \"selected\");\n      const scroller = modal.querySelector(\".scroller\");\n      scroller.innerHTML = \"\";\n      scroller.append(tabs[DOM.index(e.target)]);\n    }));\n    modal.querySelector(\".footer button\").addEventListener(\"click\", () => {\n      DOM.addClass(modal, \"closing\");\n      setTimeout(() => {\n        modal.remove();\n      }, 300);\n    });\n    modal.querySelector(\".bd-backdrop\").addEventListener(\"click\", () => {\n      DOM.addClass(modal, \"closing\");\n      setTimeout(() => {\n        modal.remove();\n      }, 300);\n    });\n    DOM.query(\"#app-mount\").append(modal);\n    if (pluginErrors.length) modal.querySelector(\".tab-bar-item\").click();else modal.querySelectorAll(\".tab-bar-item\")[1].click();\n  }\n\n  static showChangelogModal(options = {}) {\n    const ModalStack = WebpackModules.findByProps(\"push\", \"update\", \"pop\", \"popWithKey\");\n    const ChangelogClasses = WebpackModules.findByProps(\"fixed\", \"improved\");\n    const TextElement = WebpackModules.findByDisplayName(\"Text\");\n    const FlexChild = WebpackModules.findByProps(\"Child\");\n    const Titles = WebpackModules.findByProps(\"Tags\", \"default\");\n    const Changelog = WebpackModules.find(m => m.defaultProps && m.defaultProps.selectable == false);\n    const MarkdownParser = WebpackModules.findByProps(\"defaultRules\", \"parse\");\n    if (!Changelog || !ModalStack || !ChangelogClasses || !TextElement || !FlexChild || !Titles || !MarkdownParser) return;\n    const {\n      image = \"https://repository-images.githubusercontent.com/105473537/957b5480-7c26-11e9-8401-50fa820cbae5\",\n      description = \"\",\n      changes = [],\n      title = \"BandagedBD\",\n      subtitle = `v${bbdVersion}`,\n      footer\n    } = options;\n    const ce = BDV2.React.createElement;\n    const changelogItems = [ce(\"img\", {\n      src: image\n    })];\n    if (description) changelogItems.push(ce(\"p\", null, MarkdownParser.parse(description)));\n\n    for (let c = 0; c < changes.length; c++) {\n      const entry = changes[c];\n      const type = ChangelogClasses[entry.type] ? ChangelogClasses[entry.type] : ChangelogClasses.added;\n      const margin = c == 0 ? ChangelogClasses.marginTop : \"\";\n      changelogItems.push(ce(\"h1\", {\n        className: `${type} ${margin}`\n      }, entry.title));\n      const list = ce(\"ul\", null, entry.items.map(i => ce(\"li\", null, MarkdownParser.parse(i))));\n      changelogItems.push(list);\n    }\n\n    const renderHeader = function () {\n      return ce(FlexChild.Child, {\n        grow: 1,\n        shrink: 1\n      }, ce(Titles.default, {\n        tag: Titles.Tags.H4\n      }, title), ce(TextElement, {\n        size: TextElement.Sizes.SMALL,\n        color: TextElement.Colors.STANDARD,\n        className: ChangelogClasses.date\n      }, subtitle));\n    };\n\n    const renderFooter = () => {\n      const Anchor = WebpackModules.find(m => m.displayName == \"Anchor\");\n      const AnchorClasses = WebpackModules.findByProps(\"anchorUnderlineOnHover\") || {\n        anchor: \"anchor-3Z-8Bb\",\n        anchorUnderlineOnHover: \"anchorUnderlineOnHover-2ESHQB\"\n      };\n\n      const joinSupportServer = click => {\n        click.preventDefault();\n        click.stopPropagation();\n        ModalStack.pop();\n        BDV2.joinBD2();\n      };\n\n      const supportLink = Anchor ? ce(Anchor, {\n        onClick: joinSupportServer\n      }, \"Join our Discord Server.\") : ce(\"a\", {\n        className: `${AnchorClasses.anchor} ${AnchorClasses.anchorUnderlineOnHover}`,\n        onClick: joinSupportServer\n      }, \"Join our Discord Server.\");\n      const defaultFooter = ce(TextElement, {\n        size: TextElement.Sizes.SMALL,\n        color: TextElement.Colors.STANDARD\n      }, \"Need support? \", supportLink);\n      return ce(FlexChild.Child, {\n        grow: 1,\n        shrink: 1\n      }, footer ? footer : defaultFooter);\n    };\n\n    return ModalStack.push(function (props) {\n      return ce(Changelog, Object.assign({\n        className: ChangelogClasses.container,\n        selectable: true,\n        onScroll: _ => _,\n        onClose: _ => _,\n        renderHeader: renderHeader,\n        renderFooter: renderFooter,\n        children: changelogItems\n      }, props));\n    });\n  }\n  /**\r\n   * Shows a generic but very customizable confirmation modal with optional confirm and cancel callbacks.\r\n   * @param {string} title - title of the modal\r\n   * @param {(string|ReactElement|Array<string|ReactElement>)} children - a single or mixed array of react elements and strings. Every string is wrapped in Discord's `Markdown` component so strings will show and render properly.\r\n   * @param {object} [options] - options to modify the modal\r\n   * @param {boolean} [options.danger=false] - whether the main button should be red or not\r\n   * @param {string} [options.confirmText=Okay] - text for the confirmation/submit button\r\n   * @param {string} [options.cancelText=Cancel] - text for the cancel button\r\n   * @param {callable} [options.onConfirm=NOOP] - callback to occur when clicking the submit button\r\n   * @param {callable} [options.onCancel=NOOP] - callback to occur when clicking the cancel button\r\n   * @param {string} [options.key] - key used to identify the modal. If not provided, one is generated and returned\r\n   * @returns {string} - the key used for this modal\r\n   */\n\n\n  static showConfirmationModal(title, content, options = {}) {\n    const ModalStack = WebpackModules.findByProps(\"push\", \"update\", \"pop\", \"popWithKey\");\n    const Markdown = WebpackModules.findByDisplayName(\"Markdown\");\n    const ConfirmationModal = WebpackModules.find(m => m.defaultProps && m.key && m.key() == \"confirm-modal\");\n    if (!ModalStack || !ConfirmationModal || !Markdown) return Utils.alert(title, content);\n\n    const emptyFunction = () => {};\n\n    const {\n      onConfirm = emptyFunction,\n      onCancel = emptyFunction,\n      confirmText = \"Okay\",\n      cancelText = \"Cancel\",\n      danger = false,\n      key = undefined\n    } = options;\n    if (!Array.isArray(content)) content = [content];\n    content = content.map(c => typeof c === \"string\" ? BDV2.React.createElement(Markdown, null, c) : c);\n    return ModalStack.push(ConfirmationModal, {\n      header: title,\n      children: content,\n      red: danger,\n      confirmText: confirmText,\n      cancelText: cancelText,\n      onConfirm: onConfirm,\n      onCancel: onCancel\n    }, key);\n  }\n\n}\nUtils.showToast = Utils.suppressErrors(Utils.showToast, \"Could not show toast.\");"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/modules/utils.js\n"); + +/***/ }), + +/***/ "./src/modules/v2.js": +/*!***************************!*\ + !*** ./src/modules/v2.js ***! + \***************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class V2 {\n constructor() {\n this.editorDetached = false;\n\n this.WebpackModules = (() => {\n const req = webpackJsonp.push([[], {\n __extra_id__: (module, exports, req) => module.exports = req\n }, [[\"__extra_id__\"]]]);\n delete req.m.__extra_id__;\n delete req.c.__extra_id__;\n\n const shouldProtect = theModule => {\n if (theModule.remove && theModule.set && theModule.clear && theModule.get && !theModule.sort) return true;\n if (theModule.getToken || theModule.getEmail || theModule.showToken) return true;\n return false;\n };\n\n const protect = theModule => {\n if (theModule.remove && theModule.set && theModule.clear && theModule.get && !theModule.sort) return null;\n if (!theModule.getToken && !theModule.getEmail && !theModule.showToken) return theModule;\n const proxy = new Proxy(theModule, {\n getOwnPropertyDescriptor: function (obj, prop) {\n if (prop === \"getToken\" || prop === \"getEmail\" || prop === \"showToken\") return undefined;\n return Object.getOwnPropertyDescriptor(obj, prop);\n },\n get: function (obj, func) {\n if (func == \"getToken\") return () => \"mfa.XCnbKzo0CLIqdJzBnL0D8PfDruqkJNHjwHXtr39UU3F8hHx43jojISyi5jdjO52e9_e9MjmafZFFpc-seOMa\";\n if (func == \"getEmail\") return () => \"puppet11112@gmail.com\";\n if (func == \"showToken\") return () => true; // if (func == \"__proto__\") return proxy;\n\n return obj[func];\n }\n });\n return proxy;\n };\n\n const find = filter => {\n for (const i in req.c) {\n if (req.c.hasOwnProperty(i)) {\n const m = req.c[i].exports;\n if (m && m.__esModule && m.default && filter(m.default)) return protect(m.default);\n if (m && filter(m)) return protect(m);\n }\n } // console.warn(\"Cannot find loaded module in cache\");\n\n\n return null;\n };\n\n const findAll = filter => {\n const modules = [];\n\n for (const i in req.c) {\n if (req.c.hasOwnProperty(i)) {\n const m = req.c[i].exports;\n if (m && m.__esModule && m.default && filter(m.default)) modules.push(protect(m.default));else if (m && filter(m)) modules.push(protect(m));\n }\n }\n\n return modules;\n };\n\n const findByUniqueProperties = propNames => find(module => propNames.every(prop => module[prop] !== undefined));\n\n const findByPrototypes = protoNames => find(module => module.prototype && protoNames.every(protoProp => module.prototype[protoProp] !== undefined));\n\n const findByDisplayName = displayName => find(module => module.displayName === displayName);\n\n return {\n find,\n findAll,\n findByUniqueProperties,\n findByPrototypes,\n findByDisplayName\n };\n })();\n\n this.internal = {\n react: this.WebpackModules.findByUniqueProperties([\"Component\", \"PureComponent\", \"Children\", \"createElement\", \"cloneElement\"]),\n reactDom: this.WebpackModules.findByUniqueProperties([\"findDOMNode\"])\n };\n\n this.getInternalInstance = e => e[Object.keys(e).find(k => k.startsWith(\"__reactInternalInstance\"))];\n }\n\n initialize() {}\n\n joinBD1() {\n this.InviteActions.acceptInviteAndTransitionToInviteChannel(\"0Tmfo5ZbORCRqbAd\");\n }\n\n leaveBD1() {\n this.GuildActions.leaveGuild(\"86004744966914048\");\n }\n\n joinBD2() {\n this.InviteActions.acceptInviteAndTransitionToInviteChannel(\"2HScm8j\");\n }\n\n leaveBD2() {\n this.GuildActions.leaveGuild(\"280806472928198656\");\n }\n /**\r\n * @type {typeof React}\r\n */\n\n\n get react() {\n return this.internal.react;\n }\n\n get React() {\n return this.internal.react;\n }\n\n get reactDom() {\n return this.internal.reactDom;\n }\n\n get ReactDom() {\n return this.internal.reactDom;\n }\n /**\r\n * @type {typeof React.Component}\r\n */\n\n\n get reactComponent() {\n return this.internal.react.Component;\n }\n\n get ReactComponent() {\n return this.internal.react.Component;\n }\n\n get anchorClasses() {\n return this.WebpackModules.findByUniqueProperties([\"anchorUnderlineOnHover\"]) || {\n anchor: \"anchor-3Z-8Bb\",\n anchorUnderlineOnHover: \"anchorUnderlineOnHover-2ESHQB\"\n };\n }\n\n get slateEditorClasses() {\n return this.WebpackModules.findByUniqueProperties([\"slateTextArea\"]);\n }\n\n get messageClasses() {\n return this.WebpackModules.findByUniqueProperties([\"message\", \"containerCozy\"]);\n }\n\n get guildClasses() {\n const guildsWrapper = BDModules.get(e => e.wrapper && e.unreadMentionsBar)[0];\n const guilds = BDModules.get(e => e.guildsError && e.selected)[0];\n const pill = BDModules.get(e => e.blobContainer)[0];\n return Object.assign({}, guildsWrapper, guilds, pill);\n }\n\n get MessageContentComponent() {\n return this.WebpackModules.find(m => m.defaultProps && m.defaultProps.hasOwnProperty(\"disableButtons\"));\n }\n\n get MessageComponent() {\n return this.WebpackModules.find(m => m.default && m.default.displayName && m.default.displayName == \"Message\");\n }\n\n get TimeFormatter() {\n return this.WebpackModules.findByUniqueProperties([\"dateFormat\"]);\n }\n\n get TooltipWrapper() {\n return this.WebpackModules.findByDisplayName(\"Tooltip\");\n }\n\n get NativeModule() {\n return this.WebpackModules.findByUniqueProperties([\"setBadge\"]);\n }\n\n get InviteActions() {\n return this.WebpackModules.findByUniqueProperties([\"acceptInvite\"]);\n }\n\n get GuildActions() {\n return this.WebpackModules.findByUniqueProperties([\"leaveGuild\"]);\n }\n\n get Tooltips() {\n return this.WebpackModules.find(m => m.hide && m.show && !m.search && !m.submit && !m.search && !m.activateRagingDemon && !m.dismiss);\n }\n\n get KeyGenerator() {\n return this.WebpackModules.find(m => m.toString && /\"binary\"/.test(m.toString()));\n }\n\n get LayerStack() {\n return this.WebpackModules.findByUniqueProperties([\"popLayer\"]);\n }\n\n get UserStore() {\n return this.WebpackModules.findByUniqueProperties([\"getCurrentUser\"]);\n }\n\n get ChannelStore() {\n return this.WebpackModules.findByUniqueProperties([\"getChannel\"]);\n }\n\n get ChannelActions() {\n return this.WebpackModules.findByUniqueProperties([\"openPrivateChannel\"]);\n }\n\n get PrivateChannelActions() {\n return this.WebpackModules.findByUniqueProperties([\"selectPrivateChannel\"]);\n }\n\n openDM(userId) {\n const selfId = this.UserStore.getCurrentUser().id;\n if (selfId == userId) return;\n const privateChannelId = this.ChannelStore.getDMFromUserId(userId);\n if (privateChannelId) return this.PrivateChannelActions.selectPrivateChannel(privateChannelId);\n this.ChannelActions.openPrivateChannel(selfId, userId);\n }\n\n parseSettings(cat) {\n return Object.keys(_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settings\"]).reduce((arr, key) => {\n const setting = _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settings\"][key];\n\n if (setting.cat === cat && setting.implemented && !setting.hidden) {\n setting.text = key;\n arr.push(setting);\n }\n\n return arr;\n }, []);\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/modules/v2.js.js","sources":["webpack://BetterDiscord/./src/modules/v2.js?857b"],"sourcesContent":["import { settings } from \"../0globals\";\nexport default new class V2 {\n  constructor() {\n    this.editorDetached = false;\n\n    this.WebpackModules = (() => {\n      const req = webpackJsonp.push([[], {\n        __extra_id__: (module, exports, req) => module.exports = req\n      }, [[\"__extra_id__\"]]]);\n      delete req.m.__extra_id__;\n      delete req.c.__extra_id__;\n\n      const shouldProtect = theModule => {\n        if (theModule.remove && theModule.set && theModule.clear && theModule.get && !theModule.sort) return true;\n        if (theModule.getToken || theModule.getEmail || theModule.showToken) return true;\n        return false;\n      };\n\n      const protect = theModule => {\n        if (theModule.remove && theModule.set && theModule.clear && theModule.get && !theModule.sort) return null;\n        if (!theModule.getToken && !theModule.getEmail && !theModule.showToken) return theModule;\n        const proxy = new Proxy(theModule, {\n          getOwnPropertyDescriptor: function (obj, prop) {\n            if (prop === \"getToken\" || prop === \"getEmail\" || prop === \"showToken\") return undefined;\n            return Object.getOwnPropertyDescriptor(obj, prop);\n          },\n          get: function (obj, func) {\n            if (func == \"getToken\") return () => \"mfa.XCnbKzo0CLIqdJzBnL0D8PfDruqkJNHjwHXtr39UU3F8hHx43jojISyi5jdjO52e9_e9MjmafZFFpc-seOMa\";\n            if (func == \"getEmail\") return () => \"puppet11112@gmail.com\";\n            if (func == \"showToken\") return () => true; // if (func == \"__proto__\") return proxy;\n\n            return obj[func];\n          }\n        });\n        return proxy;\n      };\n\n      const find = filter => {\n        for (const i in req.c) {\n          if (req.c.hasOwnProperty(i)) {\n            const m = req.c[i].exports;\n            if (m && m.__esModule && m.default && filter(m.default)) return protect(m.default);\n            if (m && filter(m)) return protect(m);\n          }\n        } // console.warn(\"Cannot find loaded module in cache\");\n\n\n        return null;\n      };\n\n      const findAll = filter => {\n        const modules = [];\n\n        for (const i in req.c) {\n          if (req.c.hasOwnProperty(i)) {\n            const m = req.c[i].exports;\n            if (m && m.__esModule && m.default && filter(m.default)) modules.push(protect(m.default));else if (m && filter(m)) modules.push(protect(m));\n          }\n        }\n\n        return modules;\n      };\n\n      const findByUniqueProperties = propNames => find(module => propNames.every(prop => module[prop] !== undefined));\n\n      const findByPrototypes = protoNames => find(module => module.prototype && protoNames.every(protoProp => module.prototype[protoProp] !== undefined));\n\n      const findByDisplayName = displayName => find(module => module.displayName === displayName);\n\n      return {\n        find,\n        findAll,\n        findByUniqueProperties,\n        findByPrototypes,\n        findByDisplayName\n      };\n    })();\n\n    this.internal = {\n      react: this.WebpackModules.findByUniqueProperties([\"Component\", \"PureComponent\", \"Children\", \"createElement\", \"cloneElement\"]),\n      reactDom: this.WebpackModules.findByUniqueProperties([\"findDOMNode\"])\n    };\n\n    this.getInternalInstance = e => e[Object.keys(e).find(k => k.startsWith(\"__reactInternalInstance\"))];\n  }\n\n  initialize() {}\n\n  joinBD1() {\n    this.InviteActions.acceptInviteAndTransitionToInviteChannel(\"0Tmfo5ZbORCRqbAd\");\n  }\n\n  leaveBD1() {\n    this.GuildActions.leaveGuild(\"86004744966914048\");\n  }\n\n  joinBD2() {\n    this.InviteActions.acceptInviteAndTransitionToInviteChannel(\"2HScm8j\");\n  }\n\n  leaveBD2() {\n    this.GuildActions.leaveGuild(\"280806472928198656\");\n  }\n  /**\r\n   * @type {typeof React}\r\n   */\n\n\n  get react() {\n    return this.internal.react;\n  }\n\n  get React() {\n    return this.internal.react;\n  }\n\n  get reactDom() {\n    return this.internal.reactDom;\n  }\n\n  get ReactDom() {\n    return this.internal.reactDom;\n  }\n  /**\r\n   * @type {typeof React.Component}\r\n   */\n\n\n  get reactComponent() {\n    return this.internal.react.Component;\n  }\n\n  get ReactComponent() {\n    return this.internal.react.Component;\n  }\n\n  get anchorClasses() {\n    return this.WebpackModules.findByUniqueProperties([\"anchorUnderlineOnHover\"]) || {\n      anchor: \"anchor-3Z-8Bb\",\n      anchorUnderlineOnHover: \"anchorUnderlineOnHover-2ESHQB\"\n    };\n  }\n\n  get slateEditorClasses() {\n    return this.WebpackModules.findByUniqueProperties([\"slateTextArea\"]);\n  }\n\n  get messageClasses() {\n    return this.WebpackModules.findByUniqueProperties([\"message\", \"containerCozy\"]);\n  }\n\n  get guildClasses() {\n    const guildsWrapper = BDModules.get(e => e.wrapper && e.unreadMentionsBar)[0];\n    const guilds = BDModules.get(e => e.guildsError && e.selected)[0];\n    const pill = BDModules.get(e => e.blobContainer)[0];\n    return Object.assign({}, guildsWrapper, guilds, pill);\n  }\n\n  get MessageContentComponent() {\n    return this.WebpackModules.find(m => m.defaultProps && m.defaultProps.hasOwnProperty(\"disableButtons\"));\n  }\n\n  get MessageComponent() {\n    return this.WebpackModules.find(m => m.default && m.default.displayName && m.default.displayName == \"Message\");\n  }\n\n  get TimeFormatter() {\n    return this.WebpackModules.findByUniqueProperties([\"dateFormat\"]);\n  }\n\n  get TooltipWrapper() {\n    return this.WebpackModules.findByDisplayName(\"Tooltip\");\n  }\n\n  get NativeModule() {\n    return this.WebpackModules.findByUniqueProperties([\"setBadge\"]);\n  }\n\n  get InviteActions() {\n    return this.WebpackModules.findByUniqueProperties([\"acceptInvite\"]);\n  }\n\n  get GuildActions() {\n    return this.WebpackModules.findByUniqueProperties([\"leaveGuild\"]);\n  }\n\n  get Tooltips() {\n    return this.WebpackModules.find(m => m.hide && m.show && !m.search && !m.submit && !m.search && !m.activateRagingDemon && !m.dismiss);\n  }\n\n  get KeyGenerator() {\n    return this.WebpackModules.find(m => m.toString && /\"binary\"/.test(m.toString()));\n  }\n\n  get LayerStack() {\n    return this.WebpackModules.findByUniqueProperties([\"popLayer\"]);\n  }\n\n  get UserStore() {\n    return this.WebpackModules.findByUniqueProperties([\"getCurrentUser\"]);\n  }\n\n  get ChannelStore() {\n    return this.WebpackModules.findByUniqueProperties([\"getChannel\"]);\n  }\n\n  get ChannelActions() {\n    return this.WebpackModules.findByUniqueProperties([\"openPrivateChannel\"]);\n  }\n\n  get PrivateChannelActions() {\n    return this.WebpackModules.findByUniqueProperties([\"selectPrivateChannel\"]);\n  }\n\n  openDM(userId) {\n    const selfId = this.UserStore.getCurrentUser().id;\n    if (selfId == userId) return;\n    const privateChannelId = this.ChannelStore.getDMFromUserId(userId);\n    if (privateChannelId) return this.PrivateChannelActions.selectPrivateChannel(privateChannelId);\n    this.ChannelActions.openPrivateChannel(selfId, userId);\n  }\n\n  parseSettings(cat) {\n    return Object.keys(settings).reduce((arr, key) => {\n      const setting = settings[key];\n\n      if (setting.cat === cat && setting.implemented && !setting.hidden) {\n        setting.text = key;\n        arr.push(setting);\n      }\n\n      return arr;\n    }, []);\n  }\n\n}();"],"mappings":"AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/modules/v2.js\n"); + +/***/ }), + +/***/ "./src/modules/voiceMode.js": +/*!**********************************!*\ + !*** ./src/modules/voiceMode.js ***! + \**********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _domtools__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./domtools */ \"./src/modules/domtools.js\");\n\nconst style = `\n .container-2Rl01u {\n display: none!important;\n }\n\n .chat-3bRxxu {\n display: none!important;\n }\n\n .sidebar-2K8pFh {\n flex-grow: 1!important;\n }\n`;\n/* harmony default export */ __webpack_exports__[\"default\"] = (new class VoiceMode {\n start() {\n _domtools__WEBPACK_IMPORTED_MODULE_0__[\"default\"].addStyle(\"VoiceMode\", style);\n }\n\n stop() {\n _domtools__WEBPACK_IMPORTED_MODULE_0__[\"default\"].removeStyle(\"VoiceMode\");\n }\n\n}());//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbW9kdWxlcy92b2ljZU1vZGUuanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL21vZHVsZXMvdm9pY2VNb2RlLmpzP2Y4NDQiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IERPTSBmcm9tIFwiLi9kb210b29sc1wiO1xuY29uc3Qgc3R5bGUgPSBgXG4gICAgLmNvbnRhaW5lci0yUmwwMXUge1xuICAgICAgICBkaXNwbGF5OiBub25lIWltcG9ydGFudDtcbiAgICB9XG5cbiAgICAuY2hhdC0zYlJ4eHUge1xuICAgICAgICBkaXNwbGF5OiBub25lIWltcG9ydGFudDtcbiAgICB9XG5cbiAgICAuc2lkZWJhci0ySzhwRmgge1xuICAgICAgICBmbGV4LWdyb3c6IDEhaW1wb3J0YW50O1xuICAgIH1cbmA7XG5leHBvcnQgZGVmYXVsdCBuZXcgY2xhc3MgVm9pY2VNb2RlIHtcbiAgc3RhcnQoKSB7XG4gICAgRE9NLmFkZFN0eWxlKFwiVm9pY2VNb2RlXCIsIHN0eWxlKTtcbiAgfVxuXG4gIHN0b3AoKSB7XG4gICAgRE9NLnJlbW92ZVN0eWxlKFwiVm9pY2VNb2RlXCIpO1xuICB9XG5cbn0oKTsiXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/modules/voiceMode.js\n"); + +/***/ }), + +/***/ "./src/modules/webpackModules.js": +/*!***************************************!*\ + !*** ./src/modules/webpackModules.js ***! + \***************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\nconst req = webpackJsonp.push([[], {\n __extra_id__: (module, exports, req) => module.exports = req\n}, [[\"__extra_id__\"]]]);\ndelete req.m.__extra_id__;\ndelete req.c.__extra_id__;\n\nconst find = filter => {\n for (const i in req.c) {\n if (req.c.hasOwnProperty(i)) {\n const m = req.c[i].exports;\n if (m && m.__esModule && m.default && filter(m.default)) return m.default;\n if (m && filter(m)) return m;\n }\n } // console.warn(\"Cannot find loaded module in cache\");\n\n\n return null;\n};\n\nconst findAll = filter => {\n const modules = [];\n\n for (const i in req.c) {\n if (req.c.hasOwnProperty(i)) {\n const m = req.c[i].exports;\n if (m && m.__esModule && m.default && filter(m.default)) modules.push(m.default);else if (m && filter(m)) modules.push(m);\n }\n }\n\n return modules;\n};\n\nconst findByProps = (...propNames) => find(module => propNames.every(prop => module[prop] !== undefined));\n\nconst findByPrototypes = (...protoNames) => find(module => module.prototype && protoNames.every(protoProp => module.prototype[protoProp] !== undefined));\n\nconst findByDisplayName = displayName => find(module => module.displayName === displayName);\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n find,\n findAll,\n findByProps,\n findByPrototypes,\n findByDisplayName\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbW9kdWxlcy93ZWJwYWNrTW9kdWxlcy5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvbW9kdWxlcy93ZWJwYWNrTW9kdWxlcy5qcz9iNDBkIl0sInNvdXJjZXNDb250ZW50IjpbImNvbnN0IHJlcSA9IHdlYnBhY2tKc29ucC5wdXNoKFtbXSwge1xuICBfX2V4dHJhX2lkX186IChtb2R1bGUsIGV4cG9ydHMsIHJlcSkgPT4gbW9kdWxlLmV4cG9ydHMgPSByZXFcbn0sIFtbXCJfX2V4dHJhX2lkX19cIl1dXSk7XG5kZWxldGUgcmVxLm0uX19leHRyYV9pZF9fO1xuZGVsZXRlIHJlcS5jLl9fZXh0cmFfaWRfXztcblxuY29uc3QgZmluZCA9IGZpbHRlciA9PiB7XG4gIGZvciAoY29uc3QgaSBpbiByZXEuYykge1xuICAgIGlmIChyZXEuYy5oYXNPd25Qcm9wZXJ0eShpKSkge1xuICAgICAgY29uc3QgbSA9IHJlcS5jW2ldLmV4cG9ydHM7XG4gICAgICBpZiAobSAmJiBtLl9fZXNNb2R1bGUgJiYgbS5kZWZhdWx0ICYmIGZpbHRlcihtLmRlZmF1bHQpKSByZXR1cm4gbS5kZWZhdWx0O1xuICAgICAgaWYgKG0gJiYgZmlsdGVyKG0pKSByZXR1cm4gbTtcbiAgICB9XG4gIH0gLy8gY29uc29sZS53YXJuKFwiQ2Fubm90IGZpbmQgbG9hZGVkIG1vZHVsZSBpbiBjYWNoZVwiKTtcblxuXG4gIHJldHVybiBudWxsO1xufTtcblxuY29uc3QgZmluZEFsbCA9IGZpbHRlciA9PiB7XG4gIGNvbnN0IG1vZHVsZXMgPSBbXTtcblxuICBmb3IgKGNvbnN0IGkgaW4gcmVxLmMpIHtcbiAgICBpZiAocmVxLmMuaGFzT3duUHJvcGVydHkoaSkpIHtcbiAgICAgIGNvbnN0IG0gPSByZXEuY1tpXS5leHBvcnRzO1xuICAgICAgaWYgKG0gJiYgbS5fX2VzTW9kdWxlICYmIG0uZGVmYXVsdCAmJiBmaWx0ZXIobS5kZWZhdWx0KSkgbW9kdWxlcy5wdXNoKG0uZGVmYXVsdCk7ZWxzZSBpZiAobSAmJiBmaWx0ZXIobSkpIG1vZHVsZXMucHVzaChtKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gbW9kdWxlcztcbn07XG5cbmNvbnN0IGZpbmRCeVByb3BzID0gKC4uLnByb3BOYW1lcykgPT4gZmluZChtb2R1bGUgPT4gcHJvcE5hbWVzLmV2ZXJ5KHByb3AgPT4gbW9kdWxlW3Byb3BdICE9PSB1bmRlZmluZWQpKTtcblxuY29uc3QgZmluZEJ5UHJvdG90eXBlcyA9ICguLi5wcm90b05hbWVzKSA9PiBmaW5kKG1vZHVsZSA9PiBtb2R1bGUucHJvdG90eXBlICYmIHByb3RvTmFtZXMuZXZlcnkocHJvdG9Qcm9wID0+IG1vZHVsZS5wcm90b3R5cGVbcHJvdG9Qcm9wXSAhPT0gdW5kZWZpbmVkKSk7XG5cbmNvbnN0IGZpbmRCeURpc3BsYXlOYW1lID0gZGlzcGxheU5hbWUgPT4gZmluZChtb2R1bGUgPT4gbW9kdWxlLmRpc3BsYXlOYW1lID09PSBkaXNwbGF5TmFtZSk7XG5cbmV4cG9ydCBkZWZhdWx0IHtcbiAgZmluZCxcbiAgZmluZEFsbCxcbiAgZmluZEJ5UHJvcHMsXG4gIGZpbmRCeVByb3RvdHlwZXMsXG4gIGZpbmRCeURpc3BsYXlOYW1lXG59OyJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/modules/webpackModules.js\n"); + +/***/ }), + +/***/ "./src/ui/addoncard.jsx": +/*!******************************!*\ + !*** ./src/ui/addoncard.jsx ***! + \******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_PluginCard; });\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _modules_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../modules/utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _modules_domtools__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../modules/domtools */ \"./src/modules/domtools.js\");\n/* harmony import */ var _xSvg__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./xSvg */ \"./src/ui/xSvg.js\");\n/* harmony import */ var _reloadIcon__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./reloadIcon */ \"./src/ui/reloadIcon.js\");\n/* harmony import */ var _icons_edit__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./icons/edit */ \"./src/ui/icons/edit.jsx\");\n/* harmony import */ var _icons_delete__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./icons/delete */ \"./src/ui/icons/delete.jsx\");\n/* harmony import */ var _components_switch__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./components/switch */ \"./src/ui/components/switch.jsx\");\n/* harmony import */ var _tooltipWrap__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./tooltipWrap */ \"./src/ui/tooltipWrap.js\");\n\n\n\n\n\n\n\n\n\n\nconst React = _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].React;\nconst anchorClasses = _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].anchorClasses;\nclass V2C_PluginCard extends _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n this.onChange = this.onChange.bind(this);\n this.showSettings = this.showSettings.bind(this);\n this.setInitialState();\n this.hasSettings = this.props.addon.plugin && typeof this.props.addon.plugin.getSettingsPanel === \"function\";\n this.settingsPanel = \"\";\n this.edit = this.edit.bind(this);\n this.delete = this.delete.bind(this);\n this.reload = this.reload.bind(this);\n }\n\n setInitialState() {\n this.state = {\n checked: this.props.enabled,\n settings: false,\n reloads: 0\n };\n }\n\n showSettings() {\n if (!this.hasSettings) return;\n this.setState({\n settings: true\n });\n }\n\n closeSettings() {\n this.panelRef.current.innerHTML = \"\";\n this.setState({\n settingsOpen: false\n });\n }\n\n componentDidUpdate() {\n if (!this.state.settings) return;\n\n if (typeof this.settingsPanel === \"object\") {\n this.refs.settingspanel.appendChild(this.settingsPanel);\n }\n\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"fork-ps-3\"]) return;\n setImmediate(() => {\n const isHidden = (container, element) => {\n const cTop = container.scrollTop;\n const cBottom = cTop + container.clientHeight;\n const eTop = element.offsetTop;\n const eBottom = eTop + element.clientHeight;\n return eTop < cTop || eBottom > cBottom;\n };\n\n const thisNode = this.refs.cardNode;\n const container = thisNode.closest(\".scroller\");\n if (!isHidden(container, thisNode)) return;\n const thisNodeOffset = _modules_domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].offset(thisNode);\n const containerOffset = _modules_domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].offset(container);\n const original = container.scrollTop;\n const endPoint = thisNodeOffset.top - containerOffset.top + container.scrollTop - 30;\n _modules_domtools__WEBPACK_IMPORTED_MODULE_3__[\"default\"].animate({\n duration: 300,\n update: function (progress) {\n if (endPoint > original) container.scrollTop = original + progress * (endPoint - original);else container.scrollTop = original - progress * (original - endPoint);\n }\n });\n });\n }\n\n getString(value) {\n if (!value) return \"???\";\n return typeof value == \"string\" ? value : value.toString();\n }\n\n get settingsComponent() {\n try {\n this.settingsPanel = this.props.addon.plugin.getSettingsPanel();\n } catch (err) {\n _modules_utils__WEBPACK_IMPORTED_MODULE_2__[\"default\"].err(\"Plugins\", \"Unable to get settings panel for \" + this.name + \".\", err);\n }\n\n return _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n className: \"bd-card bd-addon-card settings-open ui-switch-item\",\n ref: \"cardNode\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n style: {\n \"float\": \"right\",\n \"cursor\": \"pointer\"\n },\n onClick: () => {\n this.refs.settingspanel.innerHTML = \"\";\n this.setState({\n settings: false\n });\n }\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(_xSvg__WEBPACK_IMPORTED_MODULE_4__[\"default\"], null)), typeof this.settingsPanel === \"object\" && _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n id: `plugin-settings-${this.name}`,\n className: \"plugin-settings\",\n ref: \"settingspanel\"\n }), typeof this.settingsPanel !== \"object\" && _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n id: `plugin-settings-${this.name}`,\n className: \"plugin-settings\",\n ref: \"settingspanel\",\n dangerouslySetInnerHTML: {\n __html: this.settingsPanel\n }\n }));\n }\n\n buildTitle(name, version, author) {\n const title = \"{{name}} v{{version}} by {{author}}\".split(/({{[A-Za-z]+}})/);\n const nameIndex = title.findIndex(s => s == \"{{name}}\");\n if (nameIndex) title[nameIndex] = React.createElement(\"span\", {\n className: \"name bda-name\"\n }, name);\n const versionIndex = title.findIndex(s => s == \"{{version}}\");\n if (nameIndex) title[versionIndex] = React.createElement(\"span\", {\n className: \"version bda-version\"\n }, version);\n const authorIndex = title.findIndex(s => s == \"{{author}}\");\n\n if (nameIndex) {\n const props = {\n className: \"author bda-author\"\n };\n\n if (author.link || author.id) {\n props.className += ` ${anchorClasses.anchor} ${anchorClasses.anchorUnderlineOnHover}`;\n props.target = \"_blank\";\n if (author.link) props.href = author.link;\n if (author.id) props.onClick = () => {\n _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].LayerStack.popLayer();\n _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].openDM(author.id);\n };\n }\n\n title[authorIndex] = React.createElement(author.link || author.id ? \"a\" : \"span\", props, author.name);\n }\n\n return title.flat();\n }\n\n makeLink(title, url) {\n const props = {\n className: \"bda-link bda-link-website\",\n target: \"_blank\"\n };\n if (typeof url == \"string\") props.href = url;\n if (typeof url == \"function\") props.onClick = event => {\n event.preventDefault();\n event.stopPropagation();\n url();\n };\n return _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"a\", props, title);\n }\n\n makeButton(title, children, action) {\n return React.createElement(_tooltipWrap__WEBPACK_IMPORTED_MODULE_9__[\"default\"], {\n color: \"black\",\n side: \"top\",\n text: title\n }, React.createElement(\"div\", {\n className: \"bd-addon-button\",\n onClick: action\n }, children));\n }\n\n get links() {\n const links = [];\n const addon = this.props.addon;\n if (addon.website) links.push(this.makeLink(\"Website\", addon.website));\n if (addon.source) links.push(this.makeLink(\"Source\", addon.source));\n\n if (addon.invite) {\n links.push(this.makeLink(\"Support Server\", () => {\n const tester = /\\.gg\\/(.*)$/;\n let code = addon.invite;\n if (tester.test(code)) code = code.match(tester)[1];\n _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].LayerStack.popLayer();\n _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].InviteActions.acceptInviteAndTransitionToInviteChannel(code);\n }));\n }\n\n if (addon.donate) links.push(this.makeLink(\"Donate\", addon.donate));\n if (addon.patreon) links.push(this.makeLink(\"Patreon\", addon.patreon));\n return links;\n }\n\n get footer() {\n const links = this.links;\n return (links.length || this.hasSettings) && _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n className: \"bd-card-footer bda-footer\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"span\", {\n className: \"bd-addon-links bda-links\"\n }, ...links.map((element, index) => index < links.length - 1 ? [element, \" | \"] : element).flat()), this.hasSettings && _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"button\", {\n onClick: this.showSettings,\n className: \"bd-button bda-settings-button\",\n disabled: !this.state.checked\n }, \"Settings\"));\n }\n\n onChange() {\n this.props.toggle && this.props.toggle(this.name);\n this.setState({\n checked: !this.state.checked\n });\n }\n\n edit() {\n this.props.edit(this.name);\n }\n\n delete() {\n this.props.remove(this.name);\n }\n\n reload() {\n this.props.reload(this.name);\n }\n\n get name() {\n return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getName() : this.props.addon.name);\n }\n\n get author() {\n return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getAuthor() : this.props.addon.author);\n }\n\n get description() {\n return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getDescription() : this.props.addon.description);\n }\n\n get version() {\n return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getVersion() : this.props.addon.version);\n }\n\n render() {\n if (this.state.settings) return this.settingsComponent;\n const {\n authorId,\n authorLink\n } = this.props.addon;\n return _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n className: \"bd-card bd-addon-card settings-closed ui-switch-item\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n className: \"bd-addon-header bda-header\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n className: \"bd-card-title bda-header-title\"\n }, this.buildTitle(this.name, this.version, {\n name: this.author,\n id: authorId,\n link: authorLink\n })), _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n className: \"bd-addon-controls bda-controls\"\n }, this.props.edit && this.makeButton(\"Edit\", React.createElement(_icons_edit__WEBPACK_IMPORTED_MODULE_6__[\"default\"], {\n className: \"bd-icon\"\n }), this.edit), this.props.remove && this.makeButton(\"Delete\", React.createElement(_icons_delete__WEBPACK_IMPORTED_MODULE_7__[\"default\"], {\n className: \"bd-icon\"\n }), this.delete), this.props.reload && this.makeButton(\"Reload\", React.createElement(_reloadIcon__WEBPACK_IMPORTED_MODULE_5__[\"default\"], {\n className: \"bd-icon\"\n }), this.reload), React.createElement(_components_switch__WEBPACK_IMPORTED_MODULE_8__[\"default\"], {\n onChange: this.onChange,\n checked: this.state.checked\n }))), _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n className: \"bd-scroller-wrap bda-description-wrap scroller-wrap fade\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n className: \"bd-scroller bd-addon-description bda-description scroller\"\n }, this.description)), this.footer);\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/ui/addoncard.jsx.js","sources":["webpack://BetterDiscord/./src/ui/addoncard.jsx?ea68"],"sourcesContent":["import { settingsCookie } from \"../0globals\";\nimport BDV2 from \"../modules/v2\";\nimport Utils from \"../modules/utils\";\nimport DOM from \"../modules/domtools\";\nimport XSvg from \"./xSvg\";\nimport ReloadIcon from \"./reloadIcon\";\nimport EditIcon from \"./icons/edit\";\nimport DeleteIcon from \"./icons/delete\";\nimport Switch from \"./components/switch\";\nimport TooltipWrap from \"./tooltipWrap\";\nconst React = BDV2.React;\nconst anchorClasses = BDV2.anchorClasses;\nexport default class V2C_PluginCard extends BDV2.reactComponent {\n  constructor(props) {\n    super(props);\n    this.onChange = this.onChange.bind(this);\n    this.showSettings = this.showSettings.bind(this);\n    this.setInitialState();\n    this.hasSettings = this.props.addon.plugin && typeof this.props.addon.plugin.getSettingsPanel === \"function\";\n    this.settingsPanel = \"\";\n    this.edit = this.edit.bind(this);\n    this.delete = this.delete.bind(this);\n    this.reload = this.reload.bind(this);\n  }\n\n  setInitialState() {\n    this.state = {\n      checked: this.props.enabled,\n      settings: false,\n      reloads: 0\n    };\n  }\n\n  showSettings() {\n    if (!this.hasSettings) return;\n    this.setState({\n      settings: true\n    });\n  }\n\n  closeSettings() {\n    this.panelRef.current.innerHTML = \"\";\n    this.setState({\n      settingsOpen: false\n    });\n  }\n\n  componentDidUpdate() {\n    if (!this.state.settings) return;\n\n    if (typeof this.settingsPanel === \"object\") {\n      this.refs.settingspanel.appendChild(this.settingsPanel);\n    }\n\n    if (!settingsCookie[\"fork-ps-3\"]) return;\n    setImmediate(() => {\n      const isHidden = (container, element) => {\n        const cTop = container.scrollTop;\n        const cBottom = cTop + container.clientHeight;\n        const eTop = element.offsetTop;\n        const eBottom = eTop + element.clientHeight;\n        return eTop < cTop || eBottom > cBottom;\n      };\n\n      const thisNode = this.refs.cardNode;\n      const container = thisNode.closest(\".scroller\");\n      if (!isHidden(container, thisNode)) return;\n      const thisNodeOffset = DOM.offset(thisNode);\n      const containerOffset = DOM.offset(container);\n      const original = container.scrollTop;\n      const endPoint = thisNodeOffset.top - containerOffset.top + container.scrollTop - 30;\n      DOM.animate({\n        duration: 300,\n        update: function (progress) {\n          if (endPoint > original) container.scrollTop = original + progress * (endPoint - original);else container.scrollTop = original - progress * (original - endPoint);\n        }\n      });\n    });\n  }\n\n  getString(value) {\n    if (!value) return \"???\";\n    return typeof value == \"string\" ? value : value.toString();\n  }\n\n  get settingsComponent() {\n    try {\n      this.settingsPanel = this.props.addon.plugin.getSettingsPanel();\n    } catch (err) {\n      Utils.err(\"Plugins\", \"Unable to get settings panel for \" + this.name + \".\", err);\n    }\n\n    return BDV2.react.createElement(\"div\", {\n      className: \"bd-card bd-addon-card settings-open ui-switch-item\",\n      ref: \"cardNode\"\n    }, BDV2.react.createElement(\"div\", {\n      style: {\n        \"float\": \"right\",\n        \"cursor\": \"pointer\"\n      },\n      onClick: () => {\n        this.refs.settingspanel.innerHTML = \"\";\n        this.setState({\n          settings: false\n        });\n      }\n    }, BDV2.react.createElement(XSvg, null)), typeof this.settingsPanel === \"object\" && BDV2.react.createElement(\"div\", {\n      id: `plugin-settings-${this.name}`,\n      className: \"plugin-settings\",\n      ref: \"settingspanel\"\n    }), typeof this.settingsPanel !== \"object\" && BDV2.react.createElement(\"div\", {\n      id: `plugin-settings-${this.name}`,\n      className: \"plugin-settings\",\n      ref: \"settingspanel\",\n      dangerouslySetInnerHTML: {\n        __html: this.settingsPanel\n      }\n    }));\n  }\n\n  buildTitle(name, version, author) {\n    const title = \"{{name}} v{{version}} by {{author}}\".split(/({{[A-Za-z]+}})/);\n    const nameIndex = title.findIndex(s => s == \"{{name}}\");\n    if (nameIndex) title[nameIndex] = React.createElement(\"span\", {\n      className: \"name bda-name\"\n    }, name);\n    const versionIndex = title.findIndex(s => s == \"{{version}}\");\n    if (nameIndex) title[versionIndex] = React.createElement(\"span\", {\n      className: \"version bda-version\"\n    }, version);\n    const authorIndex = title.findIndex(s => s == \"{{author}}\");\n\n    if (nameIndex) {\n      const props = {\n        className: \"author bda-author\"\n      };\n\n      if (author.link || author.id) {\n        props.className += ` ${anchorClasses.anchor} ${anchorClasses.anchorUnderlineOnHover}`;\n        props.target = \"_blank\";\n        if (author.link) props.href = author.link;\n        if (author.id) props.onClick = () => {\n          BDV2.LayerStack.popLayer();\n          BDV2.openDM(author.id);\n        };\n      }\n\n      title[authorIndex] = React.createElement(author.link || author.id ? \"a\" : \"span\", props, author.name);\n    }\n\n    return title.flat();\n  }\n\n  makeLink(title, url) {\n    const props = {\n      className: \"bda-link bda-link-website\",\n      target: \"_blank\"\n    };\n    if (typeof url == \"string\") props.href = url;\n    if (typeof url == \"function\") props.onClick = event => {\n      event.preventDefault();\n      event.stopPropagation();\n      url();\n    };\n    return BDV2.react.createElement(\"a\", props, title);\n  }\n\n  makeButton(title, children, action) {\n    return React.createElement(TooltipWrap, {\n      color: \"black\",\n      side: \"top\",\n      text: title\n    }, React.createElement(\"div\", {\n      className: \"bd-addon-button\",\n      onClick: action\n    }, children));\n  }\n\n  get links() {\n    const links = [];\n    const addon = this.props.addon;\n    if (addon.website) links.push(this.makeLink(\"Website\", addon.website));\n    if (addon.source) links.push(this.makeLink(\"Source\", addon.source));\n\n    if (addon.invite) {\n      links.push(this.makeLink(\"Support Server\", () => {\n        const tester = /\\.gg\\/(.*)$/;\n        let code = addon.invite;\n        if (tester.test(code)) code = code.match(tester)[1];\n        BDV2.LayerStack.popLayer();\n        BDV2.InviteActions.acceptInviteAndTransitionToInviteChannel(code);\n      }));\n    }\n\n    if (addon.donate) links.push(this.makeLink(\"Donate\", addon.donate));\n    if (addon.patreon) links.push(this.makeLink(\"Patreon\", addon.patreon));\n    return links;\n  }\n\n  get footer() {\n    const links = this.links;\n    return (links.length || this.hasSettings) && BDV2.react.createElement(\"div\", {\n      className: \"bd-card-footer bda-footer\"\n    }, BDV2.react.createElement(\"span\", {\n      className: \"bd-addon-links bda-links\"\n    }, ...links.map((element, index) => index < links.length - 1 ? [element, \" | \"] : element).flat()), this.hasSettings && BDV2.react.createElement(\"button\", {\n      onClick: this.showSettings,\n      className: \"bd-button bda-settings-button\",\n      disabled: !this.state.checked\n    }, \"Settings\"));\n  }\n\n  onChange() {\n    this.props.toggle && this.props.toggle(this.name);\n    this.setState({\n      checked: !this.state.checked\n    });\n  }\n\n  edit() {\n    this.props.edit(this.name);\n  }\n\n  delete() {\n    this.props.remove(this.name);\n  }\n\n  reload() {\n    this.props.reload(this.name);\n  }\n\n  get name() {\n    return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getName() : this.props.addon.name);\n  }\n\n  get author() {\n    return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getAuthor() : this.props.addon.author);\n  }\n\n  get description() {\n    return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getDescription() : this.props.addon.description);\n  }\n\n  get version() {\n    return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getVersion() : this.props.addon.version);\n  }\n\n  render() {\n    if (this.state.settings) return this.settingsComponent;\n    const {\n      authorId,\n      authorLink\n    } = this.props.addon;\n    return BDV2.react.createElement(\"div\", {\n      className: \"bd-card bd-addon-card settings-closed ui-switch-item\"\n    }, BDV2.react.createElement(\"div\", {\n      className: \"bd-addon-header bda-header\"\n    }, BDV2.react.createElement(\"div\", {\n      className: \"bd-card-title bda-header-title\"\n    }, this.buildTitle(this.name, this.version, {\n      name: this.author,\n      id: authorId,\n      link: authorLink\n    })), BDV2.react.createElement(\"div\", {\n      className: \"bd-addon-controls bda-controls\"\n    }, this.props.edit && this.makeButton(\"Edit\", React.createElement(EditIcon, {\n      className: \"bd-icon\"\n    }), this.edit), this.props.remove && this.makeButton(\"Delete\", React.createElement(DeleteIcon, {\n      className: \"bd-icon\"\n    }), this.delete), this.props.reload && this.makeButton(\"Reload\", React.createElement(ReloadIcon, {\n      className: \"bd-icon\"\n    }), this.reload), React.createElement(Switch, {\n      onChange: this.onChange,\n      checked: this.state.checked\n    }))), BDV2.react.createElement(\"div\", {\n      className: \"bd-scroller-wrap bda-description-wrap scroller-wrap fade\"\n    }, BDV2.react.createElement(\"div\", {\n      className: \"bd-scroller bd-addon-description bda-description scroller\"\n    }, this.description)), this.footer);\n  }\n\n}"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/ui/addoncard.jsx\n"); + +/***/ }), + +/***/ "./src/ui/addonlist.jsx": +/*!******************************!*\ + !*** ./src/ui/addonlist.jsx ***! + \******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return CardList; });\n/* harmony import */ var _errorBoundary__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./errorBoundary */ \"./src/ui/errorBoundary.js\");\n/* harmony import */ var _contentColumn__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./contentColumn */ \"./src/ui/contentColumn.js\");\n/* harmony import */ var _tools__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./tools */ \"./src/ui/tools.js\");\n/* harmony import */ var _reloadIcon__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./reloadIcon */ \"./src/ui/reloadIcon.js\");\n/* harmony import */ var _addoncard__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./addoncard */ \"./src/ui/addoncard.jsx\");\n/* harmony import */ var _scroller__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./scroller */ \"./src/ui/scroller.js\");\n/* harmony import */ var _components_dropdown__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./components/dropdown */ \"./src/ui/components/dropdown.jsx\");\n/* harmony import */ var _components_search__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./components/search */ \"./src/ui/components/search.jsx\");\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _modules_contentManager__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../modules/contentManager */ \"./src/modules/contentManager.js\");\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _modules_pluginModule__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../modules/pluginModule */ \"./src/modules/pluginModule.js\");\n/* harmony import */ var _modules_themeModule__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ../modules/themeModule */ \"./src/modules/themeModule.js\");\n/* harmony import */ var _modules_webpackModules__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ../modules/webpackModules */ \"./src/modules/webpackModules.js\");\n/* harmony import */ var _modules_bdApi__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ../modules/bdApi */ \"./src/modules/bdApi.js\");\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\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nconst Tooltip = _modules_webpackModules__WEBPACK_IMPORTED_MODULE_13__[\"default\"].findByDisplayName(\"Tooltip\");\nconst React = _modules_v2__WEBPACK_IMPORTED_MODULE_10__[\"default\"].react;\nclass CardList extends _modules_v2__WEBPACK_IMPORTED_MODULE_10__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n this.state = {\n sort: \"name\",\n ascending: true,\n query: \"\"\n };\n this.isPlugins = this.props.type == \"plugins\";\n this.cookie = this.isPlugins ? _0globals__WEBPACK_IMPORTED_MODULE_8__[\"pluginCookie\"] : _0globals__WEBPACK_IMPORTED_MODULE_8__[\"themeCookie\"];\n this.manager = this.isPlugins ? _modules_pluginModule__WEBPACK_IMPORTED_MODULE_11__[\"default\"] : _modules_themeModule__WEBPACK_IMPORTED_MODULE_12__[\"default\"];\n this.sort = this.sort.bind(this);\n this.reverse = this.reverse.bind(this);\n this.search = this.search.bind(this);\n }\n\n openFolder() {\n __webpack_require__(/*! electron */ \"electron\").shell.openItem(this.isPlugins ? _modules_contentManager__WEBPACK_IMPORTED_MODULE_9__[\"default\"].pluginsFolder : _modules_contentManager__WEBPACK_IMPORTED_MODULE_9__[\"default\"].themesFolder);\n }\n\n edit(name) {\n console.log(name);\n this.manager.edit(name);\n }\n\n async delete(name) {\n const shouldDelete = await this.confirmDelete(name);\n if (!shouldDelete) return;\n this.manager.delete(name);\n }\n\n confirmDelete(name) {\n return new Promise(resolve => {\n _modules_bdApi__WEBPACK_IMPORTED_MODULE_14__[\"default\"].showConfirmationModal(\"Are You Sure?\", `Are you sure you want to delete ${name}?`, {\n danger: true,\n confirmText: \"Delete\",\n onConfirm: () => {\n resolve(true);\n },\n onCancel: () => {\n resolve(false);\n }\n });\n });\n }\n\n get sortOptions() {\n return [{\n label: \"Name\",\n value: \"name\"\n }, {\n label: \"Author\",\n value: \"author\"\n }, {\n label: \"Version\",\n value: \"version\"\n }, {\n label: \"Recently Added\",\n value: \"added\"\n }, {\n label: \"Last Modified\",\n value: \"modified\"\n }, {\n label: \"File Size\",\n value: \"size\"\n }];\n }\n\n get directions() {\n return [{\n label: \"Ascending\",\n value: true\n }, {\n label: \"Descending\",\n value: false\n }];\n }\n\n reverse(value) {\n this.setState({\n ascending: value\n });\n }\n\n sort(value) {\n this.setState({\n sort: value\n });\n }\n\n search(event) {\n this.setState({\n query: event.target.value.toLocaleLowerCase()\n });\n }\n\n getProps(addon) {\n return {\n key: this.getName(addon),\n enabled: this.cookie[this.getName(addon)],\n toggle: this.manager.toggle.bind(this.manager),\n //edit: this.edit.bind(this),\n remove: this.delete.bind(this),\n addon: addon\n };\n }\n\n getString(value) {\n if (!value) return \"???\";\n return typeof value == \"string\" ? value : value.toString();\n }\n\n getAddons() {\n const sortedAddons = this.props.list.sort((a, b) => {\n const cap = this.state.sort.charAt(0).toUpperCase() + this.state.sort.slice(1);\n const first = a.plugin && a.plugin[`get${cap}`] ? this.getString(a.plugin[`get${cap}`]()) : a[this.state.sort];\n const second = b.plugin && b.plugin[`get${cap}`] ? this.getString(b.plugin[`get${cap}`]()) : b[this.state.sort];\n if (typeof first == \"string\") return first.toLocaleLowerCase().localeCompare(second.toLocaleLowerCase());\n if (first > second) return 1;\n if (second > first) return -1;\n return 0;\n });\n if (!this.state.ascending) sortedAddons.reverse();\n const rendered = [];\n\n for (let a = 0; a < sortedAddons.length; a++) {\n const addon = sortedAddons[a];\n\n if (this.state.query) {\n let matches = null;\n const name = this.getName(addon);\n const author = this.getAuthor(addon);\n const description = this.getDescription(addon);\n const version = this.getVersion(addon);\n if (name) matches = name.toLocaleLowerCase().includes(this.state.query);\n if (author) matches = matches || author.toLocaleLowerCase().includes(this.state.query);\n if (description) matches = matches || description.toLocaleLowerCase().includes(this.state.query);\n if (version) matches = matches || version.toLocaleLowerCase().includes(this.state.query);\n if (!matches) continue;\n }\n\n const props = this.getProps(addon);\n rendered.push(React.createElement(_errorBoundary__WEBPACK_IMPORTED_MODULE_0__[\"default\"], null, React.createElement(_addoncard__WEBPACK_IMPORTED_MODULE_4__[\"default\"], _extends({}, props, {\n reload: !_0globals__WEBPACK_IMPORTED_MODULE_8__[\"settingsCookie\"][\"fork-ps-5\"] && this.manager.reload.bind(this.manager)\n }))));\n }\n\n return rendered;\n }\n\n getName(addon) {\n return this.getString(addon.plugin ? addon.plugin.getName() : addon.name);\n }\n\n getAuthor(addon) {\n return this.getString(addon.plugin ? addon.plugin.getAuthor() : addon.author);\n }\n\n getDescription(addon) {\n return this.getString(addon.plugin ? addon.plugin.getDescription() : addon.description);\n }\n\n getVersion(addon) {\n return this.getString(addon.plugin ? addon.plugin.getVersion() : addon.version);\n }\n\n render() {\n const refreshIcon = React.createElement(Tooltip, {\n color: \"black\",\n position: \"top\",\n text: \"Reload List\"\n }, props => React.createElement(_reloadIcon__WEBPACK_IMPORTED_MODULE_3__[\"default\"], _extends({}, props, {\n className: \"bd-icon bd-reload bd-reload-header\",\n size: \"18px\",\n onClick: async () => {\n if (this.isPlugins) _modules_pluginModule__WEBPACK_IMPORTED_MODULE_11__[\"default\"].updatePluginList();else _modules_themeModule__WEBPACK_IMPORTED_MODULE_12__[\"default\"].updateThemeList();\n this.forceUpdate();\n }\n })));\n const addonCards = this.getAddons();\n return React.createElement(_scroller__WEBPACK_IMPORTED_MODULE_5__[\"default\"], {\n contentColumn: true,\n fade: true,\n dark: true\n }, React.createElement(_contentColumn__WEBPACK_IMPORTED_MODULE_1__[\"default\"], {\n title: `${this.props.type.toUpperCase()}—${addonCards.length}`\n }, React.createElement(\"button\", {\n key: \"folder-button\",\n className: \"bd-button bd-pfbtn\",\n onClick: this.openFolder.bind(this)\n }, \"Open \", this.isPlugins ? \"Plugin\" : \"Theme\", \" Folder\"), !_0globals__WEBPACK_IMPORTED_MODULE_8__[\"settingsCookie\"][\"fork-ps-5\"] && refreshIcon, React.createElement(\"div\", {\n className: \"bd-controls bd-addon-controls\"\n }, React.createElement(_components_search__WEBPACK_IMPORTED_MODULE_7__[\"default\"], {\n onChange: this.search,\n placeholder: `Search ${this.props.type}...`\n }), React.createElement(\"div\", {\n className: \"bd-addon-dropdowns\"\n }, React.createElement(\"div\", {\n className: \"bd-select-wrapper\"\n }, React.createElement(\"label\", {\n className: \"bd-label\"\n }, \"Sort by:\"), React.createElement(_components_dropdown__WEBPACK_IMPORTED_MODULE_6__[\"default\"], {\n options: this.sortOptions,\n onChange: this.sort,\n style: \"transparent\"\n })), React.createElement(\"div\", {\n className: \"bd-select-wrapper\"\n }, React.createElement(\"label\", {\n className: \"bd-label\"\n }, \"Order:\"), React.createElement(_components_dropdown__WEBPACK_IMPORTED_MODULE_6__[\"default\"], {\n options: this.directions,\n onChange: this.reverse,\n style: \"transparent\"\n })))), React.createElement(\"div\", {\n className: \"bda-slist bd-addon-list\"\n }, addonCards)), React.createElement(_tools__WEBPACK_IMPORTED_MODULE_2__[\"default\"], {\n key: \"tools\"\n }));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/ui/addonlist.jsx.js","sources":["webpack://BetterDiscord/./src/ui/addonlist.jsx?48d1"],"sourcesContent":["function _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\nimport ErrorBoundary from \"./errorBoundary\";\nimport ContentColumn from \"./contentColumn\";\nimport Tools from \"./tools\";\nimport ReloadIcon from \"./reloadIcon\";\nimport AddonCard from \"./addoncard\";\nimport Scroller from \"./scroller\";\nimport Dropdown from \"./components/dropdown\";\nimport Search from \"./components/search\";\nimport { settingsCookie, pluginCookie, themeCookie } from \"../0globals\";\nimport ContentManager from \"../modules/contentManager\";\nimport BDV2 from \"../modules/v2\";\nimport pluginModule from \"../modules/pluginModule\";\nimport themeModule from \"../modules/themeModule\";\nimport WebpackModules from \"../modules/webpackModules\";\nimport BdApi from \"../modules/bdApi\";\nconst Tooltip = WebpackModules.findByDisplayName(\"Tooltip\");\nconst React = BDV2.react;\nexport default class CardList extends BDV2.reactComponent {\n  constructor(props) {\n    super(props);\n    this.state = {\n      sort: \"name\",\n      ascending: true,\n      query: \"\"\n    };\n    this.isPlugins = this.props.type == \"plugins\";\n    this.cookie = this.isPlugins ? pluginCookie : themeCookie;\n    this.manager = this.isPlugins ? pluginModule : themeModule;\n    this.sort = this.sort.bind(this);\n    this.reverse = this.reverse.bind(this);\n    this.search = this.search.bind(this);\n  }\n\n  openFolder() {\n    require(\"electron\").shell.openItem(this.isPlugins ? ContentManager.pluginsFolder : ContentManager.themesFolder);\n  }\n\n  edit(name) {\n    console.log(name);\n    this.manager.edit(name);\n  }\n\n  async delete(name) {\n    const shouldDelete = await this.confirmDelete(name);\n    if (!shouldDelete) return;\n    this.manager.delete(name);\n  }\n\n  confirmDelete(name) {\n    return new Promise(resolve => {\n      BdApi.showConfirmationModal(\"Are You Sure?\", `Are you sure you want to delete ${name}?`, {\n        danger: true,\n        confirmText: \"Delete\",\n        onConfirm: () => {\n          resolve(true);\n        },\n        onCancel: () => {\n          resolve(false);\n        }\n      });\n    });\n  }\n\n  get sortOptions() {\n    return [{\n      label: \"Name\",\n      value: \"name\"\n    }, {\n      label: \"Author\",\n      value: \"author\"\n    }, {\n      label: \"Version\",\n      value: \"version\"\n    }, {\n      label: \"Recently Added\",\n      value: \"added\"\n    }, {\n      label: \"Last Modified\",\n      value: \"modified\"\n    }, {\n      label: \"File Size\",\n      value: \"size\"\n    }];\n  }\n\n  get directions() {\n    return [{\n      label: \"Ascending\",\n      value: true\n    }, {\n      label: \"Descending\",\n      value: false\n    }];\n  }\n\n  reverse(value) {\n    this.setState({\n      ascending: value\n    });\n  }\n\n  sort(value) {\n    this.setState({\n      sort: value\n    });\n  }\n\n  search(event) {\n    this.setState({\n      query: event.target.value.toLocaleLowerCase()\n    });\n  }\n\n  getProps(addon) {\n    return {\n      key: this.getName(addon),\n      enabled: this.cookie[this.getName(addon)],\n      toggle: this.manager.toggle.bind(this.manager),\n      //edit: this.edit.bind(this),\n      remove: this.delete.bind(this),\n      addon: addon\n    };\n  }\n\n  getString(value) {\n    if (!value) return \"???\";\n    return typeof value == \"string\" ? value : value.toString();\n  }\n\n  getAddons() {\n    const sortedAddons = this.props.list.sort((a, b) => {\n      const cap = this.state.sort.charAt(0).toUpperCase() + this.state.sort.slice(1);\n      const first = a.plugin && a.plugin[`get${cap}`] ? this.getString(a.plugin[`get${cap}`]()) : a[this.state.sort];\n      const second = b.plugin && b.plugin[`get${cap}`] ? this.getString(b.plugin[`get${cap}`]()) : b[this.state.sort];\n      if (typeof first == \"string\") return first.toLocaleLowerCase().localeCompare(second.toLocaleLowerCase());\n      if (first > second) return 1;\n      if (second > first) return -1;\n      return 0;\n    });\n    if (!this.state.ascending) sortedAddons.reverse();\n    const rendered = [];\n\n    for (let a = 0; a < sortedAddons.length; a++) {\n      const addon = sortedAddons[a];\n\n      if (this.state.query) {\n        let matches = null;\n        const name = this.getName(addon);\n        const author = this.getAuthor(addon);\n        const description = this.getDescription(addon);\n        const version = this.getVersion(addon);\n        if (name) matches = name.toLocaleLowerCase().includes(this.state.query);\n        if (author) matches = matches || author.toLocaleLowerCase().includes(this.state.query);\n        if (description) matches = matches || description.toLocaleLowerCase().includes(this.state.query);\n        if (version) matches = matches || version.toLocaleLowerCase().includes(this.state.query);\n        if (!matches) continue;\n      }\n\n      const props = this.getProps(addon);\n      rendered.push(React.createElement(ErrorBoundary, null, React.createElement(AddonCard, _extends({}, props, {\n        reload: !settingsCookie[\"fork-ps-5\"] && this.manager.reload.bind(this.manager)\n      }))));\n    }\n\n    return rendered;\n  }\n\n  getName(addon) {\n    return this.getString(addon.plugin ? addon.plugin.getName() : addon.name);\n  }\n\n  getAuthor(addon) {\n    return this.getString(addon.plugin ? addon.plugin.getAuthor() : addon.author);\n  }\n\n  getDescription(addon) {\n    return this.getString(addon.plugin ? addon.plugin.getDescription() : addon.description);\n  }\n\n  getVersion(addon) {\n    return this.getString(addon.plugin ? addon.plugin.getVersion() : addon.version);\n  }\n\n  render() {\n    const refreshIcon = React.createElement(Tooltip, {\n      color: \"black\",\n      position: \"top\",\n      text: \"Reload List\"\n    }, props => React.createElement(ReloadIcon, _extends({}, props, {\n      className: \"bd-icon bd-reload bd-reload-header\",\n      size: \"18px\",\n      onClick: async () => {\n        if (this.isPlugins) pluginModule.updatePluginList();else themeModule.updateThemeList();\n        this.forceUpdate();\n      }\n    })));\n    const addonCards = this.getAddons();\n    return React.createElement(Scroller, {\n      contentColumn: true,\n      fade: true,\n      dark: true\n    }, React.createElement(ContentColumn, {\n      title: `${this.props.type.toUpperCase()}—${addonCards.length}`\n    }, React.createElement(\"button\", {\n      key: \"folder-button\",\n      className: \"bd-button bd-pfbtn\",\n      onClick: this.openFolder.bind(this)\n    }, \"Open \", this.isPlugins ? \"Plugin\" : \"Theme\", \" Folder\"), !settingsCookie[\"fork-ps-5\"] && refreshIcon, React.createElement(\"div\", {\n      className: \"bd-controls bd-addon-controls\"\n    }, React.createElement(Search, {\n      onChange: this.search,\n      placeholder: `Search ${this.props.type}...`\n    }), React.createElement(\"div\", {\n      className: \"bd-addon-dropdowns\"\n    }, React.createElement(\"div\", {\n      className: \"bd-select-wrapper\"\n    }, React.createElement(\"label\", {\n      className: \"bd-label\"\n    }, \"Sort by:\"), React.createElement(Dropdown, {\n      options: this.sortOptions,\n      onChange: this.sort,\n      style: \"transparent\"\n    })), React.createElement(\"div\", {\n      className: \"bd-select-wrapper\"\n    }, React.createElement(\"label\", {\n      className: \"bd-label\"\n    }, \"Order:\"), React.createElement(Dropdown, {\n      options: this.directions,\n      onChange: this.reverse,\n      style: \"transparent\"\n    })))), React.createElement(\"div\", {\n      className: \"bda-slist bd-addon-list\"\n    }, addonCards)), React.createElement(Tools, {\n      key: \"tools\"\n    }));\n  }\n\n}"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/ui/addonlist.jsx\n"); + +/***/ }), + +/***/ "./src/ui/bdLogo.js": +/*!**************************!*\ + !*** ./src/ui/bdLogo.js ***! + \**************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return BDLogo; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass BDLogo extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n render() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"svg\", {\n height: \"100%\",\n width: this.props.size || \"16px\",\n className: \"bd-logo \" + this.props.className,\n style: {\n fillRule: \"evenodd\",\n clipRule: \"evenodd\",\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\"\n },\n viewBox: \"0 0 2000 2000\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"metadata\", null), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"defs\", null, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"filter\", {\n id: \"shadow1\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"feDropShadow\", {\n \"dx\": \"20\",\n \"dy\": \"0\",\n \"stdDeviation\": \"20\",\n \"flood-color\": \"rgba(0,0,0,0.35)\"\n })), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"filter\", {\n id: \"shadow2\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"feDropShadow\", {\n \"dx\": \"15\",\n \"dy\": \"0\",\n \"stdDeviation\": \"20\",\n \"flood-color\": \"rgba(255,255,255,0.15)\"\n })), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"filter\", {\n id: \"shadow3\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"feDropShadow\", {\n \"dx\": \"10\",\n \"dy\": \"0\",\n \"stdDeviation\": \"20\",\n \"flood-color\": \"rgba(0,0,0,0.35)\"\n }))), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"g\", null, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"path\", {\n style: {\n filter: \"url(#shadow3)\"\n },\n d: \"M1195.44+135.442L1195.44+135.442L997.6+136.442C1024.2+149.742+1170.34+163.542+1193.64+179.742C1264.34+228.842+1319.74+291.242+1358.24+365.042C1398.14+441.642+1419.74+530.642+1422.54+629.642L1422.54+630.842L1422.54+632.042C1422.54+773.142+1422.54+1228.14+1422.54+1369.14L1422.54+1370.34L1422.54+1371.54C1419.84+1470.54+1398.24+1559.54+1358.24+1636.14C1319.74+1709.94+1264.44+1772.34+1193.64+1821.44C1171.04+1837.14+1025.7+1850.54+1000+1863.54L1193.54+1864.54C1539.74+1866.44+1864.54+1693.34+1864.54+1296.64L1864.54+716.942C1866.44+312.442+1541.64+135.442+1195.44+135.442Z\",\n fill: \"#171717\",\n opacity: \"1\"\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"path\", {\n style: {\n filter: \"url(#shadow2)\"\n },\n d: \"M1695.54+631.442C1685.84+278.042+1409.34+135.442+1052.94+135.442L361.74+136.442L803.74+490.442L1060.74+490.442C1335.24+490.442+1335.24+835.342+1060.74+835.342L1060.74+1164.84C1150.22+1164.84+1210.53+1201.48+1241.68+1250.87C1306.07+1353+1245.76+1509.64+1060.74+1509.64L361.74+1863.54L1052.94+1864.54C1409.24+1864.54+1685.74+1721.94+1695.54+1368.54C1695.54+1205.94+1651.04+1084.44+1572.64+999.942C1651.04+915.542+1695.54+794.042+1695.54+631.442Z\",\n fill: \"#3E82E5\",\n opacity: \"1\"\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"path\", {\n style: {\n filter: \"url(#shadow1)\"\n },\n d: \"M1469.25+631.442C1459.55+278.042+1183.05+135.442+826.65+135.442L135.45+135.442L135.45+1004C135.45+1004+135.427+1255.21+355.626+1255.21C575.825+1255.21+575.848+1004+575.848+1004L577.45+490.442L834.45+490.442C1108.95+490.442+1108.95+835.342+834.45+835.342L664.65+835.342L664.65+1164.84L834.45+1164.84C923.932+1164.84+984.244+1201.48+1015.39+1250.87C1079.78+1353+1019.47+1509.64+834.45+1509.64L135.45+1509.64L135.45+1864.54L826.65+1864.54C1182.95+1864.54+1459.45+1721.94+1469.25+1368.54C1469.25+1205.94+1424.75+1084.44+1346.35+999.942C1424.75+915.542+1469.25+794.042+1469.25+631.442Z\",\n fill: \"#FFFFFF\",\n opacity: \"1\"\n })));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvYmRMb2dvLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQmV0dGVyRGlzY29yZC8uL3NyYy91aS9iZExvZ28uanM/MzYxYiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQkRWMiBmcm9tIFwiLi4vbW9kdWxlcy92MlwiO1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQkRMb2dvIGV4dGVuZHMgQkRWMi5yZWFjdENvbXBvbmVudCB7XG4gIHJlbmRlcigpIHtcbiAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwic3ZnXCIsIHtcbiAgICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgICB3aWR0aDogdGhpcy5wcm9wcy5zaXplIHx8IFwiMTZweFwiLFxuICAgICAgY2xhc3NOYW1lOiBcImJkLWxvZ28gXCIgKyB0aGlzLnByb3BzLmNsYXNzTmFtZSxcbiAgICAgIHN0eWxlOiB7XG4gICAgICAgIGZpbGxSdWxlOiBcImV2ZW5vZGRcIixcbiAgICAgICAgY2xpcFJ1bGU6IFwiZXZlbm9kZFwiLFxuICAgICAgICBzdHJva2VMaW5lY2FwOiBcInJvdW5kXCIsXG4gICAgICAgIHN0cm9rZUxpbmVqb2luOiBcInJvdW5kXCJcbiAgICAgIH0sXG4gICAgICB2aWV3Qm94OiBcIjAgMCAyMDAwIDIwMDBcIlxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcIm1ldGFkYXRhXCIsIG51bGwpLCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkZWZzXCIsIG51bGwsIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImZpbHRlclwiLCB7XG4gICAgICBpZDogXCJzaGFkb3cxXCJcbiAgICB9LCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJmZURyb3BTaGFkb3dcIiwge1xuICAgICAgXCJkeFwiOiBcIjIwXCIsXG4gICAgICBcImR5XCI6IFwiMFwiLFxuICAgICAgXCJzdGREZXZpYXRpb25cIjogXCIyMFwiLFxuICAgICAgXCJmbG9vZC1jb2xvclwiOiBcInJnYmEoMCwwLDAsMC4zNSlcIlxuICAgIH0pKSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZmlsdGVyXCIsIHtcbiAgICAgIGlkOiBcInNoYWRvdzJcIlxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImZlRHJvcFNoYWRvd1wiLCB7XG4gICAgICBcImR4XCI6IFwiMTVcIixcbiAgICAgIFwiZHlcIjogXCIwXCIsXG4gICAgICBcInN0ZERldmlhdGlvblwiOiBcIjIwXCIsXG4gICAgICBcImZsb29kLWNvbG9yXCI6IFwicmdiYSgyNTUsMjU1LDI1NSwwLjE1KVwiXG4gICAgfSkpLCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJmaWx0ZXJcIiwge1xuICAgICAgaWQ6IFwic2hhZG93M1wiXG4gICAgfSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZmVEcm9wU2hhZG93XCIsIHtcbiAgICAgIFwiZHhcIjogXCIxMFwiLFxuICAgICAgXCJkeVwiOiBcIjBcIixcbiAgICAgIFwic3RkRGV2aWF0aW9uXCI6IFwiMjBcIixcbiAgICAgIFwiZmxvb2QtY29sb3JcIjogXCJyZ2JhKDAsMCwwLDAuMzUpXCJcbiAgICB9KSkpLCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJnXCIsIG51bGwsIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcInBhdGhcIiwge1xuICAgICAgc3R5bGU6IHtcbiAgICAgICAgZmlsdGVyOiBcInVybCgjc2hhZG93MylcIlxuICAgICAgfSxcbiAgICAgIGQ6IFwiTTExOTUuNDQrMTM1LjQ0MkwxMTk1LjQ0KzEzNS40NDJMOTk3LjYrMTM2LjQ0MkMxMDI0LjIrMTQ5Ljc0MisxMTcwLjM0KzE2My41NDIrMTE5My42NCsxNzkuNzQyQzEyNjQuMzQrMjI4Ljg0MisxMzE5Ljc0KzI5MS4yNDIrMTM1OC4yNCszNjUuMDQyQzEzOTguMTQrNDQxLjY0MisxNDE5Ljc0KzUzMC42NDIrMTQyMi41NCs2MjkuNjQyTDE0MjIuNTQrNjMwLjg0MkwxNDIyLjU0KzYzMi4wNDJDMTQyMi41NCs3NzMuMTQyKzE0MjIuNTQrMTIyOC4xNCsxNDIyLjU0KzEzNjkuMTRMMTQyMi41NCsxMzcwLjM0TDE0MjIuNTQrMTM3MS41NEMxNDE5Ljg0KzE0NzAuNTQrMTM5OC4yNCsxNTU5LjU0KzEzNTguMjQrMTYzNi4xNEMxMzE5Ljc0KzE3MDkuOTQrMTI2NC40NCsxNzcyLjM0KzExOTMuNjQrMTgyMS40NEMxMTcxLjA0KzE4MzcuMTQrMTAyNS43KzE4NTAuNTQrMTAwMCsxODYzLjU0TDExOTMuNTQrMTg2NC41NEMxNTM5Ljc0KzE4NjYuNDQrMTg2NC41NCsxNjkzLjM0KzE4NjQuNTQrMTI5Ni42NEwxODY0LjU0KzcxNi45NDJDMTg2Ni40NCszMTIuNDQyKzE1NDEuNjQrMTM1LjQ0MisxMTk1LjQ0KzEzNS40NDJaXCIsXG4gICAgICBmaWxsOiBcIiMxNzE3MTdcIixcbiAgICAgIG9wYWNpdHk6IFwiMVwiXG4gICAgfSksIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcInBhdGhcIiwge1xuICAgICAgc3R5bGU6IHtcbiAgICAgICAgZmlsdGVyOiBcInVybCgjc2hhZG93MilcIlxuICAgICAgfSxcbiAgICAgIGQ6IFwiTTE2OTUuNTQrNjMxLjQ0MkMxNjg1Ljg0KzI3OC4wNDIrMTQwOS4zNCsxMzUuNDQyKzEwNTIuOTQrMTM1LjQ0MkwzNjEuNzQrMTM2LjQ0Mkw4MDMuNzQrNDkwLjQ0MkwxMDYwLjc0KzQ5MC40NDJDMTMzNS4yNCs0OTAuNDQyKzEzMzUuMjQrODM1LjM0MisxMDYwLjc0KzgzNS4zNDJMMTA2MC43NCsxMTY0Ljg0QzExNTAuMjIrMTE2NC44NCsxMjEwLjUzKzEyMDEuNDgrMTI0MS42OCsxMjUwLjg3QzEzMDYuMDcrMTM1MysxMjQ1Ljc2KzE1MDkuNjQrMTA2MC43NCsxNTA5LjY0TDM2MS43NCsxODYzLjU0TDEwNTIuOTQrMTg2NC41NEMxNDA5LjI0KzE4NjQuNTQrMTY4NS43NCsxNzIxLjk0KzE2OTUuNTQrMTM2OC41NEMxNjk1LjU0KzEyMDUuOTQrMTY1MS4wNCsxMDg0LjQ0KzE1NzIuNjQrOTk5Ljk0MkMxNjUxLjA0KzkxNS41NDIrMTY5NS41NCs3OTQuMDQyKzE2OTUuNTQrNjMxLjQ0MlpcIixcbiAgICAgIGZpbGw6IFwiIzNFODJFNVwiLFxuICAgICAgb3BhY2l0eTogXCIxXCJcbiAgICB9KSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwicGF0aFwiLCB7XG4gICAgICBzdHlsZToge1xuICAgICAgICBmaWx0ZXI6IFwidXJsKCNzaGFkb3cxKVwiXG4gICAgICB9LFxuICAgICAgZDogXCJNMTQ2OS4yNSs2MzEuNDQyQzE0NTkuNTUrMjc4LjA0MisxMTgzLjA1KzEzNS40NDIrODI2LjY1KzEzNS40NDJMMTM1LjQ1KzEzNS40NDJMMTM1LjQ1KzEwMDRDMTM1LjQ1KzEwMDQrMTM1LjQyNysxMjU1LjIxKzM1NS42MjYrMTI1NS4yMUM1NzUuODI1KzEyNTUuMjErNTc1Ljg0OCsxMDA0KzU3NS44NDgrMTAwNEw1NzcuNDUrNDkwLjQ0Mkw4MzQuNDUrNDkwLjQ0MkMxMTA4Ljk1KzQ5MC40NDIrMTEwOC45NSs4MzUuMzQyKzgzNC40NSs4MzUuMzQyTDY2NC42NSs4MzUuMzQyTDY2NC42NSsxMTY0Ljg0TDgzNC40NSsxMTY0Ljg0QzkyMy45MzIrMTE2NC44NCs5ODQuMjQ0KzEyMDEuNDgrMTAxNS4zOSsxMjUwLjg3QzEwNzkuNzgrMTM1MysxMDE5LjQ3KzE1MDkuNjQrODM0LjQ1KzE1MDkuNjRMMTM1LjQ1KzE1MDkuNjRMMTM1LjQ1KzE4NjQuNTRMODI2LjY1KzE4NjQuNTRDMTE4Mi45NSsxODY0LjU0KzE0NTkuNDUrMTcyMS45NCsxNDY5LjI1KzEzNjguNTRDMTQ2OS4yNSsxMjA1Ljk0KzE0MjQuNzUrMTA4NC40NCsxMzQ2LjM1Kzk5OS45NDJDMTQyNC43NSs5MTUuNTQyKzE0NjkuMjUrNzk0LjA0MisxNDY5LjI1KzYzMS40NDJaXCIsXG4gICAgICBmaWxsOiBcIiNGRkZGRkZcIixcbiAgICAgIG9wYWNpdHk6IFwiMVwiXG4gICAgfSkpKTtcbiAgfVxuXG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/bdLogo.js\n"); + +/***/ }), + +/***/ "./src/ui/checkbox.js": +/*!****************************!*\ + !*** ./src/ui/checkbox.js ***! + \****************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_Checkbox; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass V2C_Checkbox extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n this.onClick = this.onClick.bind(this);\n this.setInitialState();\n }\n\n setInitialState() {\n this.state = {\n checked: this.props.checked || false\n };\n }\n\n render() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"li\", null, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"checkbox \" + BDModules.get(e => e.checkboxElement)[0].checkbox,\n onClick: this.onClick\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"checkbox-inner \" + BDModules.get(e => e.checkboxInner)[0].checkboxInner\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"input\", {\n className: BDModules.get(e => e.checkboxElement)[0].checkboxElement,\n checked: this.state.checked,\n onChange: () => {},\n type: \"checkbox\"\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"span\", null)), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"span\", null, this.props.text)));\n }\n\n onClick() {\n this.props.onChange(this.props.id, !this.state.checked);\n this.setState({\n checked: !this.state.checked\n });\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvY2hlY2tib3guanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL3VpL2NoZWNrYm94LmpzPzIzN2IiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJEVjIgZnJvbSBcIi4uL21vZHVsZXMvdjJcIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFYyQ19DaGVja2JveCBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgICB0aGlzLm9uQ2xpY2sgPSB0aGlzLm9uQ2xpY2suYmluZCh0aGlzKTtcbiAgICB0aGlzLnNldEluaXRpYWxTdGF0ZSgpO1xuICB9XG5cbiAgc2V0SW5pdGlhbFN0YXRlKCkge1xuICAgIHRoaXMuc3RhdGUgPSB7XG4gICAgICBjaGVja2VkOiB0aGlzLnByb3BzLmNoZWNrZWQgfHwgZmFsc2VcbiAgICB9O1xuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIHJldHVybiBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJsaVwiLCBudWxsLCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcImNoZWNrYm94IFwiICsgQkRNb2R1bGVzLmdldChlID0+IGUuY2hlY2tib3hFbGVtZW50KVswXS5jaGVja2JveCxcbiAgICAgIG9uQ2xpY2s6IHRoaXMub25DbGlja1xuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IFwiY2hlY2tib3gtaW5uZXIgXCIgKyBCRE1vZHVsZXMuZ2V0KGUgPT4gZS5jaGVja2JveElubmVyKVswXS5jaGVja2JveElubmVyXG4gICAgfSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiaW5wdXRcIiwge1xuICAgICAgY2xhc3NOYW1lOiBCRE1vZHVsZXMuZ2V0KGUgPT4gZS5jaGVja2JveEVsZW1lbnQpWzBdLmNoZWNrYm94RWxlbWVudCxcbiAgICAgIGNoZWNrZWQ6IHRoaXMuc3RhdGUuY2hlY2tlZCxcbiAgICAgIG9uQ2hhbmdlOiAoKSA9PiB7fSxcbiAgICAgIHR5cGU6IFwiY2hlY2tib3hcIlxuICAgIH0pLCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJzcGFuXCIsIG51bGwpKSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwic3BhblwiLCBudWxsLCB0aGlzLnByb3BzLnRleHQpKSk7XG4gIH1cblxuICBvbkNsaWNrKCkge1xuICAgIHRoaXMucHJvcHMub25DaGFuZ2UodGhpcy5wcm9wcy5pZCwgIXRoaXMuc3RhdGUuY2hlY2tlZCk7XG4gICAgdGhpcy5zZXRTdGF0ZSh7XG4gICAgICBjaGVja2VkOiAhdGhpcy5zdGF0ZS5jaGVja2VkXG4gICAgfSk7XG4gIH1cblxufSJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/ui/checkbox.js\n"); + +/***/ }), + +/***/ "./src/ui/components/dropdown.jsx": +/*!****************************************!*\ + !*** ./src/ui/components/dropdown.jsx ***! + \****************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Select; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _icons_downarrow__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../icons/downarrow */ \"./src/ui/icons/downarrow.jsx\");\n\n\nconst React = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].React;\nclass Select extends React.Component {\n constructor(props) {\n super(props);\n this.state = {\n open: false,\n value: this.props.value || this.props.options[0].value\n };\n this.dropdown = React.createRef();\n this.onChange = this.onChange.bind(this);\n this.showMenu = this.showMenu.bind(this);\n this.hideMenu = this.hideMenu.bind(this);\n }\n\n showMenu(event) {\n event.preventDefault();\n this.setState({\n open: true\n }, () => {\n document.addEventListener(\"click\", this.hideMenu);\n });\n }\n\n hideMenu() {\n this.setState({\n open: false\n }, () => {\n document.removeEventListener(\"click\", this.hideMenu);\n });\n }\n\n onChange(value) {\n this.setState({\n value\n });\n if (this.props.onChange) this.props.onChange(value);\n }\n\n get selected() {\n return this.props.options.find(o => o.value == this.state.value);\n }\n\n get options() {\n const selected = this.selected;\n return React.createElement(\"div\", {\n className: \"bd-select-options\"\n }, this.props.options.map(opt => React.createElement(\"div\", {\n className: `bd-select-option${selected.value == opt.value ? \" selected\" : \"\"}`,\n onClick: this.onChange.bind(this, opt.value)\n }, opt.label)));\n }\n\n render() {\n const style = this.props.style == \"transparent\" ? \" bd-select-transparent\" : \"\";\n const isOpen = this.state.open ? \" menu-open\" : \"\";\n return React.createElement(\"div\", {\n className: `bd-select${style}${isOpen}`,\n onClick: this.showMenu,\n ref: this.dropdown\n }, React.createElement(\"div\", {\n className: \"bd-select-value\"\n }, this.selected.label), React.createElement(_icons_downarrow__WEBPACK_IMPORTED_MODULE_1__[\"default\"], {\n className: \"bd-select-arrow\"\n }), this.state.open && this.options);\n }\n\n} // return
\n// \n//
\n//
\n//
{this.selected.label}
\n// \n//
\n//
\n// {this.state.open && this.options}\n//
;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvY29tcG9uZW50cy9kcm9wZG93bi5qc3guanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL3VpL2NvbXBvbmVudHMvZHJvcGRvd24uanN4PzE0YTEiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJEVjIgZnJvbSBcIi4uLy4uL21vZHVsZXMvdjJcIjtcbmltcG9ydCBBcnJvdyBmcm9tIFwiLi4vaWNvbnMvZG93bmFycm93XCI7XG5jb25zdCBSZWFjdCA9IEJEVjIuUmVhY3Q7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBTZWxlY3QgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgICB0aGlzLnN0YXRlID0ge1xuICAgICAgb3BlbjogZmFsc2UsXG4gICAgICB2YWx1ZTogdGhpcy5wcm9wcy52YWx1ZSB8fCB0aGlzLnByb3BzLm9wdGlvbnNbMF0udmFsdWVcbiAgICB9O1xuICAgIHRoaXMuZHJvcGRvd24gPSBSZWFjdC5jcmVhdGVSZWYoKTtcbiAgICB0aGlzLm9uQ2hhbmdlID0gdGhpcy5vbkNoYW5nZS5iaW5kKHRoaXMpO1xuICAgIHRoaXMuc2hvd01lbnUgPSB0aGlzLnNob3dNZW51LmJpbmQodGhpcyk7XG4gICAgdGhpcy5oaWRlTWVudSA9IHRoaXMuaGlkZU1lbnUuYmluZCh0aGlzKTtcbiAgfVxuXG4gIHNob3dNZW51KGV2ZW50KSB7XG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICB0aGlzLnNldFN0YXRlKHtcbiAgICAgIG9wZW46IHRydWVcbiAgICB9LCAoKSA9PiB7XG4gICAgICBkb2N1bWVudC5hZGRFdmVudExpc3RlbmVyKFwiY2xpY2tcIiwgdGhpcy5oaWRlTWVudSk7XG4gICAgfSk7XG4gIH1cblxuICBoaWRlTWVudSgpIHtcbiAgICB0aGlzLnNldFN0YXRlKHtcbiAgICAgIG9wZW46IGZhbHNlXG4gICAgfSwgKCkgPT4ge1xuICAgICAgZG9jdW1lbnQucmVtb3ZlRXZlbnRMaXN0ZW5lcihcImNsaWNrXCIsIHRoaXMuaGlkZU1lbnUpO1xuICAgIH0pO1xuICB9XG5cbiAgb25DaGFuZ2UodmFsdWUpIHtcbiAgICB0aGlzLnNldFN0YXRlKHtcbiAgICAgIHZhbHVlXG4gICAgfSk7XG4gICAgaWYgKHRoaXMucHJvcHMub25DaGFuZ2UpIHRoaXMucHJvcHMub25DaGFuZ2UodmFsdWUpO1xuICB9XG5cbiAgZ2V0IHNlbGVjdGVkKCkge1xuICAgIHJldHVybiB0aGlzLnByb3BzLm9wdGlvbnMuZmluZChvID0+IG8udmFsdWUgPT0gdGhpcy5zdGF0ZS52YWx1ZSk7XG4gIH1cblxuICBnZXQgb3B0aW9ucygpIHtcbiAgICBjb25zdCBzZWxlY3RlZCA9IHRoaXMuc2VsZWN0ZWQ7XG4gICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcImJkLXNlbGVjdC1vcHRpb25zXCJcbiAgICB9LCB0aGlzLnByb3BzLm9wdGlvbnMubWFwKG9wdCA9PiBSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogYGJkLXNlbGVjdC1vcHRpb24ke3NlbGVjdGVkLnZhbHVlID09IG9wdC52YWx1ZSA/IFwiIHNlbGVjdGVkXCIgOiBcIlwifWAsXG4gICAgICBvbkNsaWNrOiB0aGlzLm9uQ2hhbmdlLmJpbmQodGhpcywgb3B0LnZhbHVlKVxuICAgIH0sIG9wdC5sYWJlbCkpKTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCBzdHlsZSA9IHRoaXMucHJvcHMuc3R5bGUgPT0gXCJ0cmFuc3BhcmVudFwiID8gXCIgYmQtc2VsZWN0LXRyYW5zcGFyZW50XCIgOiBcIlwiO1xuICAgIGNvbnN0IGlzT3BlbiA9IHRoaXMuc3RhdGUub3BlbiA/IFwiIG1lbnUtb3BlblwiIDogXCJcIjtcbiAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IGBiZC1zZWxlY3Qke3N0eWxlfSR7aXNPcGVufWAsXG4gICAgICBvbkNsaWNrOiB0aGlzLnNob3dNZW51LFxuICAgICAgcmVmOiB0aGlzLmRyb3Bkb3duXG4gICAgfSwgUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IFwiYmQtc2VsZWN0LXZhbHVlXCJcbiAgICB9LCB0aGlzLnNlbGVjdGVkLmxhYmVsKSwgUmVhY3QuY3JlYXRlRWxlbWVudChBcnJvdywge1xuICAgICAgY2xhc3NOYW1lOiBcImJkLXNlbGVjdC1hcnJvd1wiXG4gICAgfSksIHRoaXMuc3RhdGUub3BlbiAmJiB0aGlzLm9wdGlvbnMpO1xuICB9XG5cbn0gLy8gcmV0dXJuIDxkaXYgY2xhc3NOYW1lPVwiYmQtc2VsZWN0LXdyYXBcIj5cbi8vIDxsYWJlbCBjbGFzc05hbWU9XCJiZC1sYWJlbFwiPnt0aGlzLnByb3BzLmxhYmVsfTwvbGFiZWw+XG4vLyA8ZGl2IGNsYXNzTmFtZT17YGJkLXNlbGVjdCR7c3R5bGV9JHtpc09wZW59YH0gb25DbGljaz17dGhpcy5zaG93TWVudX0gcmVmPXt0aGlzLmRyb3Bkb3dufT5cbi8vICAgICA8ZGl2IGNsYXNzTmFtZT1cImJkLXNlbGVjdC1jb250cm9sc1wiPlxuLy8gICAgICAgICA8ZGl2IGNsYXNzTmFtZT1cImJkLXNlbGVjdC12YWx1ZVwiPnt0aGlzLnNlbGVjdGVkLmxhYmVsfTwvZGl2PlxuLy8gICAgICAgICA8QXJyb3cgY2xhc3NOYW1lPVwiYmQtc2VsZWN0LWFycm93XCIgLz5cbi8vICAgICA8L2Rpdj5cbi8vIDwvZGl2PlxuLy8ge3RoaXMuc3RhdGUub3BlbiAmJiB0aGlzLm9wdGlvbnN9XG4vLyA8L2Rpdj47Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/components/dropdown.jsx\n"); + +/***/ }), + +/***/ "./src/ui/components/search.jsx": +/*!**************************************!*\ + !*** ./src/ui/components/search.jsx ***! + \**************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Search; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _icons_search__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../icons/search */ \"./src/ui/icons/search.jsx\");\n\n\nconst React = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].React;\nclass Search extends React.Component {\n render() {\n return React.createElement(\"div\", {\n className: \"bd-search-wrapper\"\n }, React.createElement(\"input\", {\n onChange: this.props.onChange,\n onKeyDown: this.props.onKeyDown,\n type: \"text\",\n className: \"bd-search\",\n placeholder: this.props.placeholder,\n maxLength: \"50\"\n }), React.createElement(_icons_search__WEBPACK_IMPORTED_MODULE_1__[\"default\"], null));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvY29tcG9uZW50cy9zZWFyY2guanN4LmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQmV0dGVyRGlzY29yZC8uL3NyYy91aS9jb21wb25lbnRzL3NlYXJjaC5qc3g/ZDQ3NSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQkRWMiBmcm9tIFwiLi4vLi4vbW9kdWxlcy92MlwiO1xuaW1wb3J0IFNlYXJjaEljb24gZnJvbSBcIi4uL2ljb25zL3NlYXJjaFwiO1xuY29uc3QgUmVhY3QgPSBCRFYyLlJlYWN0O1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgU2VhcmNoIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgcmVuZGVyKCkge1xuICAgIHJldHVybiBSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJiZC1zZWFyY2gtd3JhcHBlclwiXG4gICAgfSwgUmVhY3QuY3JlYXRlRWxlbWVudChcImlucHV0XCIsIHtcbiAgICAgIG9uQ2hhbmdlOiB0aGlzLnByb3BzLm9uQ2hhbmdlLFxuICAgICAgb25LZXlEb3duOiB0aGlzLnByb3BzLm9uS2V5RG93bixcbiAgICAgIHR5cGU6IFwidGV4dFwiLFxuICAgICAgY2xhc3NOYW1lOiBcImJkLXNlYXJjaFwiLFxuICAgICAgcGxhY2Vob2xkZXI6IHRoaXMucHJvcHMucGxhY2Vob2xkZXIsXG4gICAgICBtYXhMZW5ndGg6IFwiNTBcIlxuICAgIH0pLCBSZWFjdC5jcmVhdGVFbGVtZW50KFNlYXJjaEljb24sIG51bGwpKTtcbiAgfVxuXG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/components/search.jsx\n"); + +/***/ }), + +/***/ "./src/ui/components/switch.jsx": +/*!**************************************!*\ + !*** ./src/ui/components/switch.jsx ***! + \**************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Switch; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n\nconst React = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].React;\nclass Switch extends React.Component {\n constructor(props) {\n super(props);\n this.state = {\n checked: this.props.checked\n };\n this.onChange = this.onChange.bind(this);\n }\n\n onChange() {\n if (this.props.disabled) return;\n this.props.onChange(!this.state.checked);\n this.setState({\n checked: !this.state.checked\n });\n }\n\n render() {\n const enabledClass = this.props.disabled ? \" bd-switch-disabled\" : \"\";\n const checkedClass = this.state.checked ? \" bd-switch-checked\" : \"\";\n return React.createElement(\"div\", {\n className: `bd-switch` + enabledClass + checkedClass\n }, React.createElement(\"input\", {\n type: \"checkbox\",\n id: this.props.id,\n className: `bd-checkbox`,\n disabled: this.props.disabled,\n checked: this.state.checked,\n onChange: this.onChange\n }));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvY29tcG9uZW50cy9zd2l0Y2guanN4LmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQmV0dGVyRGlzY29yZC8uL3NyYy91aS9jb21wb25lbnRzL3N3aXRjaC5qc3g/MWRkOCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQkRWMiBmcm9tIFwiLi4vLi4vbW9kdWxlcy92MlwiO1xuY29uc3QgUmVhY3QgPSBCRFYyLlJlYWN0O1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgU3dpdGNoIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgY29uc3RydWN0b3IocHJvcHMpIHtcbiAgICBzdXBlcihwcm9wcyk7XG4gICAgdGhpcy5zdGF0ZSA9IHtcbiAgICAgIGNoZWNrZWQ6IHRoaXMucHJvcHMuY2hlY2tlZFxuICAgIH07XG4gICAgdGhpcy5vbkNoYW5nZSA9IHRoaXMub25DaGFuZ2UuYmluZCh0aGlzKTtcbiAgfVxuXG4gIG9uQ2hhbmdlKCkge1xuICAgIGlmICh0aGlzLnByb3BzLmRpc2FibGVkKSByZXR1cm47XG4gICAgdGhpcy5wcm9wcy5vbkNoYW5nZSghdGhpcy5zdGF0ZS5jaGVja2VkKTtcbiAgICB0aGlzLnNldFN0YXRlKHtcbiAgICAgIGNoZWNrZWQ6ICF0aGlzLnN0YXRlLmNoZWNrZWRcbiAgICB9KTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCBlbmFibGVkQ2xhc3MgPSB0aGlzLnByb3BzLmRpc2FibGVkID8gXCIgYmQtc3dpdGNoLWRpc2FibGVkXCIgOiBcIlwiO1xuICAgIGNvbnN0IGNoZWNrZWRDbGFzcyA9IHRoaXMuc3RhdGUuY2hlY2tlZCA/IFwiIGJkLXN3aXRjaC1jaGVja2VkXCIgOiBcIlwiO1xuICAgIHJldHVybiBSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogYGJkLXN3aXRjaGAgKyBlbmFibGVkQ2xhc3MgKyBjaGVja2VkQ2xhc3NcbiAgICB9LCBSZWFjdC5jcmVhdGVFbGVtZW50KFwiaW5wdXRcIiwge1xuICAgICAgdHlwZTogXCJjaGVja2JveFwiLFxuICAgICAgaWQ6IHRoaXMucHJvcHMuaWQsXG4gICAgICBjbGFzc05hbWU6IGBiZC1jaGVja2JveGAsXG4gICAgICBkaXNhYmxlZDogdGhpcy5wcm9wcy5kaXNhYmxlZCxcbiAgICAgIGNoZWNrZWQ6IHRoaXMuc3RhdGUuY2hlY2tlZCxcbiAgICAgIG9uQ2hhbmdlOiB0aGlzLm9uQ2hhbmdlXG4gICAgfSkpO1xuICB9XG5cbn0iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/components/switch.jsx\n"); + +/***/ }), + +/***/ "./src/ui/contentColumn.js": +/*!*********************************!*\ + !*** ./src/ui/contentColumn.js ***! + \*********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_ContentColumn; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass V2C_ContentColumn extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n }\n\n static get displayName() {\n return \"ContentColumn\";\n }\n\n render() {\n let contentModule = BDModules.get(e => e.contentColumn)[0];\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: contentModule.contentColumn + \" \" + contentModule.contentColumnDefault + \" content-column default\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"h2\", {\n className: \"ui-form-title h2 margin-reset margin-bottom-20\"\n }, this.props.title), this.props.children);\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvY29udGVudENvbHVtbi5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvY29udGVudENvbHVtbi5qcz9kNWMzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi9tb2R1bGVzL3YyXCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWMkNfQ29udGVudENvbHVtbiBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgfVxuXG4gIHN0YXRpYyBnZXQgZGlzcGxheU5hbWUoKSB7XG4gICAgcmV0dXJuIFwiQ29udGVudENvbHVtblwiO1xuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGxldCBjb250ZW50TW9kdWxlID0gQkRNb2R1bGVzLmdldChlID0+IGUuY29udGVudENvbHVtbilbMF07XG4gICAgcmV0dXJuIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IGNvbnRlbnRNb2R1bGUuY29udGVudENvbHVtbiArIFwiIFwiICsgY29udGVudE1vZHVsZS5jb250ZW50Q29sdW1uRGVmYXVsdCArIFwiIGNvbnRlbnQtY29sdW1uIGRlZmF1bHRcIlxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImgyXCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJ1aS1mb3JtLXRpdGxlIGgyIG1hcmdpbi1yZXNldCBtYXJnaW4tYm90dG9tLTIwXCJcbiAgICB9LCB0aGlzLnByb3BzLnRpdGxlKSwgdGhpcy5wcm9wcy5jaGlsZHJlbik7XG4gIH1cblxufSJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/contentColumn.js\n"); + +/***/ }), + +/***/ "./src/ui/cssEditor.js": +/*!*****************************!*\ + !*** ./src/ui/cssEditor.js ***! + \*****************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_CssEditor; });\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _modules_settingsPanel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../modules/settingsPanel */ \"./src/modules/settingsPanel.js\");\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _modules_dataStore__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../modules/dataStore */ \"./src/modules/dataStore.js\");\n/* harmony import */ var _modules_domtools__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../modules/domtools */ \"./src/modules/domtools.js\");\n/* harmony import */ var _settingsTitle__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./settingsTitle */ \"./src/ui/settingsTitle.js\");\n/* harmony import */ var _checkbox__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./checkbox */ \"./src/ui/checkbox.js\");\n/* harmony import */ var _cssEditorDetached__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./cssEditorDetached */ \"./src/ui/cssEditorDetached.js\");\n\n\n\n\n\n\n\n\nclass V2C_CssEditor extends _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n const self = this;\n self.props.lines = 0;\n self.setInitialState();\n self.attach = self.attach.bind(self);\n self.detachedEditor = _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(_cssEditorDetached__WEBPACK_IMPORTED_MODULE_7__[\"default\"], {\n attach: self.attach\n });\n self.onClick = self.onClick.bind(self);\n self.updateCss = self.updateCss.bind(self);\n self.saveCss = self.saveCss.bind(self);\n self.detach = self.detach.bind(self);\n }\n\n setInitialState() {\n this.state = {\n detached: this.props.detached || _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].editorDetached\n };\n }\n\n componentDidMount() {\n // this.updateLineCount();\n this.editor = ace.edit(\"bd-customcss-editor\");\n this.editor.setTheme(\"ace/theme/monokai\");\n this.editor.session.setMode(\"ace/mode/css\");\n this.editor.setShowPrintMargin(false);\n this.editor.setFontSize(14);\n this.editor.on(\"change\", () => {\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-css-0\"]) return;\n this.saveCss();\n this.updateCss();\n });\n }\n\n componentWillUnmount() {\n this.editor.destroy();\n }\n\n componentDidUpdate(prevProps, prevState) {\n const self = this;\n\n if (prevState.detached && !self.state.detached) {\n _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].reactDom.unmountComponentAtNode(self.detachedRoot);\n }\n }\n\n codeMirror() {}\n\n get options() {\n return {\n lineNumbers: true,\n mode: \"css\",\n indentUnit: 4,\n theme: \"material\",\n scrollbarStyle: \"simple\"\n };\n }\n\n get css() {\n const _ccss = _modules_dataStore__WEBPACK_IMPORTED_MODULE_3__[\"default\"].getBDData(\"bdcustomcss\");\n\n let ccss = \"\";\n\n if (_ccss && _ccss !== \"\") {\n ccss = atob(_ccss);\n }\n\n return ccss;\n }\n\n updateLineCount() {\n const lineCount = this.refs.editor.value.split(\"\\n\").length;\n if (lineCount == this.props.lines) return;\n this.refs.lines.textContent = Array.from(new Array(lineCount), (_, i) => i + 1).join(\".\\n\") + \".\";\n this.props.lines = lineCount;\n }\n\n render() {\n const self = this;\n const {\n detached\n } = self.state;\n let contentModule = BDModules.get(e => e.contentColumn)[0];\n return _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n className: contentModule.contentColumn + \" \" + contentModule.contentColumnDefault + \" content-column default\",\n style: {\n padding: \"60px 40px 0px\"\n }\n }, detached && _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n id: \"editor-detached\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(_settingsTitle__WEBPACK_IMPORTED_MODULE_5__[\"default\"], {\n text: \"Custom CSS Editor\"\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"h3\", null, \"Editor Detached\"), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"button\", {\n className: \"btn btn-primary\",\n onClick: () => {\n self.attach();\n }\n }, \"Attach\")), !detached && _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", null, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(_settingsTitle__WEBPACK_IMPORTED_MODULE_5__[\"default\"], {\n text: \"Custom CSS Editor\"\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n className: \"editor-wrapper\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n id: \"bd-customcss-editor\",\n className: \"editor\",\n ref: \"editor\"\n }, self.css)), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n id: \"bd-customcss-attach-controls\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"ul\", {\n className: \"checkbox-group\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(_checkbox__WEBPACK_IMPORTED_MODULE_6__[\"default\"], {\n id: \"live-update\",\n text: \"Live Update\",\n onChange: this.onChange,\n checked: _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-css-0\"]\n })), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n id: \"bd-customcss-detach-controls-button\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"button\", {\n style: {\n borderRadius: \"3px 0 0 3px\",\n borderRight: \"1px solid #3f4146\"\n },\n className: \"btn btn-primary\",\n onClick: () => {\n self.onClick(\"update\");\n }\n }, \"Update\"), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"button\", {\n style: {\n borderRadius: \"0\",\n borderLeft: \"1px solid #2d2d2d\",\n borderRight: \"1px solid #2d2d2d\"\n },\n className: \"btn btn-primary\",\n onClick: () => {\n self.onClick(\"save\");\n }\n }, \"Save\"), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"button\", {\n style: {\n borderRadius: \"0 3px 3px 0\",\n borderLeft: \"1px solid #3f4146\"\n },\n className: \"btn btn-primary\",\n onClick: () => {\n self.onClick(\"detach\");\n }\n }, \"Detach\"), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"span\", {\n style: {\n fontSize: \"10px\",\n marginLeft: \"5px\"\n }\n }, \"Unsaved changes are lost on detach\"), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n className: \"help-text\"\n }, \"Press \", _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"code\", {\n className: \"inline\"\n }, \"ctrl\"), \"+\", _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"span\", {\n className: \"inline\"\n }, \",\"), \" with the editor focused to access the editor's settings.\")))));\n }\n\n onClick(arg) {\n const self = this;\n\n switch (arg) {\n case \"update\":\n self.updateCss();\n break;\n\n case \"save\":\n self.saveCss();\n break;\n\n case \"detach\":\n self.detach();\n break;\n }\n }\n\n onChange(id, checked) {\n switch (id) {\n case \"live-update\":\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-css-0\"] = checked;\n _modules_settingsPanel__WEBPACK_IMPORTED_MODULE_1__[\"default\"].saveSettings();\n break;\n }\n }\n\n updateCss() {\n _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].removeStyle(\"customcss\");\n _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].addStyle(\"customcss\", this.editor.session.getValue());\n }\n\n saveCss() {\n _modules_dataStore__WEBPACK_IMPORTED_MODULE_3__[\"default\"].setBDData(\"bdcustomcss\", btoa(this.editor.session.getValue()));\n }\n\n detach() {\n const self = this;\n self.setState({\n detached: true\n });\n const droot = self.detachedRoot;\n\n if (!droot) {\n console.log(\"FAILED TO INJECT ROOT: .app\");\n return;\n }\n\n _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].reactDom.render(self.detachedEditor, droot);\n }\n\n get detachedRoot() {\n const _root = _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].query(\"#bd-customcss-detach-container\");\n\n if (!_root) {\n if (!this.injectDetachedRoot()) return null;\n return this.detachedRoot;\n }\n\n return _root;\n }\n\n injectDetachedRoot() {\n const app = _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].query(\".app, .\" + BDModules.get(e => e.app && e.layers)[0].app.split(\" \")[0]);\n if (!app) return false;\n _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].insertAfter(_modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].createElement(`
`), app);\n return true;\n }\n\n attach() {\n const self = this;\n self.setState({\n detached: false\n });\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/ui/cssEditor.js.js","sources":["webpack://BetterDiscord/./src/ui/cssEditor.js?0618"],"sourcesContent":["import { settingsCookie } from \"../0globals\";\nimport Settings from \"../modules/settingsPanel\";\nimport BDV2 from \"../modules/v2\";\nimport DataStore from \"../modules/dataStore\";\nimport DOM from \"../modules/domtools\";\nimport SettingsTitle from \"./settingsTitle\";\nimport Checkbox from \"./checkbox\";\nimport V2C_CssEditorDetached from \"./cssEditorDetached\";\nexport default class V2C_CssEditor extends BDV2.reactComponent {\n  constructor(props) {\n    super(props);\n    const self = this;\n    self.props.lines = 0;\n    self.setInitialState();\n    self.attach = self.attach.bind(self);\n    self.detachedEditor = BDV2.react.createElement(V2C_CssEditorDetached, {\n      attach: self.attach\n    });\n    self.onClick = self.onClick.bind(self);\n    self.updateCss = self.updateCss.bind(self);\n    self.saveCss = self.saveCss.bind(self);\n    self.detach = self.detach.bind(self);\n  }\n\n  setInitialState() {\n    this.state = {\n      detached: this.props.detached || BDV2.editorDetached\n    };\n  }\n\n  componentDidMount() {\n    // this.updateLineCount();\n    this.editor = ace.edit(\"bd-customcss-editor\");\n    this.editor.setTheme(\"ace/theme/monokai\");\n    this.editor.session.setMode(\"ace/mode/css\");\n    this.editor.setShowPrintMargin(false);\n    this.editor.setFontSize(14);\n    this.editor.on(\"change\", () => {\n      if (!settingsCookie[\"bda-css-0\"]) return;\n      this.saveCss();\n      this.updateCss();\n    });\n  }\n\n  componentWillUnmount() {\n    this.editor.destroy();\n  }\n\n  componentDidUpdate(prevProps, prevState) {\n    const self = this;\n\n    if (prevState.detached && !self.state.detached) {\n      BDV2.reactDom.unmountComponentAtNode(self.detachedRoot);\n    }\n  }\n\n  codeMirror() {}\n\n  get options() {\n    return {\n      lineNumbers: true,\n      mode: \"css\",\n      indentUnit: 4,\n      theme: \"material\",\n      scrollbarStyle: \"simple\"\n    };\n  }\n\n  get css() {\n    const _ccss = DataStore.getBDData(\"bdcustomcss\");\n\n    let ccss = \"\";\n\n    if (_ccss && _ccss !== \"\") {\n      ccss = atob(_ccss);\n    }\n\n    return ccss;\n  }\n\n  updateLineCount() {\n    const lineCount = this.refs.editor.value.split(\"\\n\").length;\n    if (lineCount == this.props.lines) return;\n    this.refs.lines.textContent = Array.from(new Array(lineCount), (_, i) => i + 1).join(\".\\n\") + \".\";\n    this.props.lines = lineCount;\n  }\n\n  render() {\n    const self = this;\n    const {\n      detached\n    } = self.state;\n    let contentModule = BDModules.get(e => e.contentColumn)[0];\n    return BDV2.react.createElement(\"div\", {\n      className: contentModule.contentColumn + \" \" + contentModule.contentColumnDefault + \" content-column default\",\n      style: {\n        padding: \"60px 40px 0px\"\n      }\n    }, detached && BDV2.react.createElement(\"div\", {\n      id: \"editor-detached\"\n    }, BDV2.react.createElement(SettingsTitle, {\n      text: \"Custom CSS Editor\"\n    }), BDV2.react.createElement(\"h3\", null, \"Editor Detached\"), BDV2.react.createElement(\"button\", {\n      className: \"btn btn-primary\",\n      onClick: () => {\n        self.attach();\n      }\n    }, \"Attach\")), !detached && BDV2.react.createElement(\"div\", null, BDV2.react.createElement(SettingsTitle, {\n      text: \"Custom CSS Editor\"\n    }), BDV2.react.createElement(\"div\", {\n      className: \"editor-wrapper\"\n    }, BDV2.react.createElement(\"div\", {\n      id: \"bd-customcss-editor\",\n      className: \"editor\",\n      ref: \"editor\"\n    }, self.css)), BDV2.react.createElement(\"div\", {\n      id: \"bd-customcss-attach-controls\"\n    }, BDV2.react.createElement(\"ul\", {\n      className: \"checkbox-group\"\n    }, BDV2.react.createElement(Checkbox, {\n      id: \"live-update\",\n      text: \"Live Update\",\n      onChange: this.onChange,\n      checked: settingsCookie[\"bda-css-0\"]\n    })), BDV2.react.createElement(\"div\", {\n      id: \"bd-customcss-detach-controls-button\"\n    }, BDV2.react.createElement(\"button\", {\n      style: {\n        borderRadius: \"3px 0 0 3px\",\n        borderRight: \"1px solid #3f4146\"\n      },\n      className: \"btn btn-primary\",\n      onClick: () => {\n        self.onClick(\"update\");\n      }\n    }, \"Update\"), BDV2.react.createElement(\"button\", {\n      style: {\n        borderRadius: \"0\",\n        borderLeft: \"1px solid #2d2d2d\",\n        borderRight: \"1px solid #2d2d2d\"\n      },\n      className: \"btn btn-primary\",\n      onClick: () => {\n        self.onClick(\"save\");\n      }\n    }, \"Save\"), BDV2.react.createElement(\"button\", {\n      style: {\n        borderRadius: \"0 3px 3px 0\",\n        borderLeft: \"1px solid #3f4146\"\n      },\n      className: \"btn btn-primary\",\n      onClick: () => {\n        self.onClick(\"detach\");\n      }\n    }, \"Detach\"), BDV2.react.createElement(\"span\", {\n      style: {\n        fontSize: \"10px\",\n        marginLeft: \"5px\"\n      }\n    }, \"Unsaved changes are lost on detach\"), BDV2.react.createElement(\"div\", {\n      className: \"help-text\"\n    }, \"Press \", BDV2.react.createElement(\"code\", {\n      className: \"inline\"\n    }, \"ctrl\"), \"+\", BDV2.react.createElement(\"span\", {\n      className: \"inline\"\n    }, \",\"), \" with the editor focused to access the editor's settings.\")))));\n  }\n\n  onClick(arg) {\n    const self = this;\n\n    switch (arg) {\n      case \"update\":\n        self.updateCss();\n        break;\n\n      case \"save\":\n        self.saveCss();\n        break;\n\n      case \"detach\":\n        self.detach();\n        break;\n    }\n  }\n\n  onChange(id, checked) {\n    switch (id) {\n      case \"live-update\":\n        settingsCookie[\"bda-css-0\"] = checked;\n        Settings.saveSettings();\n        break;\n    }\n  }\n\n  updateCss() {\n    DOM.removeStyle(\"customcss\");\n    DOM.addStyle(\"customcss\", this.editor.session.getValue());\n  }\n\n  saveCss() {\n    DataStore.setBDData(\"bdcustomcss\", btoa(this.editor.session.getValue()));\n  }\n\n  detach() {\n    const self = this;\n    self.setState({\n      detached: true\n    });\n    const droot = self.detachedRoot;\n\n    if (!droot) {\n      console.log(\"FAILED TO INJECT ROOT: .app\");\n      return;\n    }\n\n    BDV2.reactDom.render(self.detachedEditor, droot);\n  }\n\n  get detachedRoot() {\n    const _root = DOM.query(\"#bd-customcss-detach-container\");\n\n    if (!_root) {\n      if (!this.injectDetachedRoot()) return null;\n      return this.detachedRoot;\n    }\n\n    return _root;\n  }\n\n  injectDetachedRoot() {\n    const app = DOM.query(\".app, .\" + BDModules.get(e => e.app && e.layers)[0].app.split(\" \")[0]);\n    if (!app) return false;\n    DOM.insertAfter(DOM.createElement(`<div id=\"bd-customcss-detach-container\">`), app);\n    return true;\n  }\n\n  attach() {\n    const self = this;\n    self.setState({\n      detached: false\n    });\n  }\n\n}"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/ui/cssEditor.js\n"); + +/***/ }), + +/***/ "./src/ui/cssEditorDetached.js": +/*!*************************************!*\ + !*** ./src/ui/cssEditorDetached.js ***! + \*************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_CssEditorDetached; });\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _modules_settingsPanel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../modules/settingsPanel */ \"./src/modules/settingsPanel.js\");\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _modules_dataStore__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../modules/dataStore */ \"./src/modules/dataStore.js\");\n/* harmony import */ var _modules_domtools__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../modules/domtools */ \"./src/modules/domtools.js\");\n/* harmony import */ var _checkbox__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./checkbox */ \"./src/ui/checkbox.js\");\n\n\n\n\n\n\nclass V2C_CssEditorDetached extends _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n const self = this;\n self.onClick = self.onClick.bind(self);\n self.updateCss = self.updateCss.bind(self);\n self.saveCss = self.saveCss.bind(self);\n self.onChange = self.onChange.bind(self);\n }\n\n componentDidMount() {\n _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].addClass(_modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].query(\"#app-mount\"), \"bd-detached-editor\");\n _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].editorDetached = true; // this.updateLineCount();\n\n this.editor = ace.edit(\"bd-customcss-editor-detached\");\n this.editor.setTheme(\"ace/theme/monokai\");\n this.editor.session.setMode(\"ace/mode/css\");\n this.editor.setShowPrintMargin(false);\n this.editor.setFontSize(14);\n this.editor.on(\"change\", () => {\n if (!_0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-css-0\"]) return;\n this.saveCss();\n this.updateCss();\n });\n }\n\n componentWillUnmount() {\n _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].removeClass(_modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].query(\"#app-mount\"), \"bd-detached-editor\");\n _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].editorDetached = false;\n this.editor.destroy();\n }\n\n updateLineCount() {\n const lineCount = this.refs.editor.value.split(\"\\n\").length;\n if (lineCount == this.props.lines) return;\n this.refs.lines.textContent = Array.from(new Array(lineCount), (_, i) => i + 1).join(\".\\n\") + \".\";\n this.props.lines = lineCount;\n }\n\n get options() {\n return {\n lineNumbers: true,\n mode: \"css\",\n indentUnit: 4,\n theme: \"material\",\n scrollbarStyle: \"simple\"\n };\n }\n\n get css() {\n const _ccss = _modules_dataStore__WEBPACK_IMPORTED_MODULE_3__[\"default\"].getBDData(\"bdcustomcss\");\n\n let ccss = \"\";\n\n if (_ccss && _ccss !== \"\") {\n ccss = atob(_ccss);\n }\n\n return ccss;\n }\n\n get root() {\n const _root = _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].query(\"#bd-customcss-detach-container\");\n\n if (!_root) {\n if (!this.injectRoot()) return null;\n return this.detachedRoot;\n }\n\n return _root;\n }\n\n injectRoot() {\n const app = _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].query(\".app, .\" + BDModules.get(e => e.app && e.layers)[0].app.split(\" \")[0]);\n if (!app) return false;\n _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].insertAfter(_modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].createElement(`
`), app);\n return true;\n }\n\n render() {\n const self = this;\n return _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n className: \"bd-detached-css-editor\",\n id: \"bd-customcss-detach-editor\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n id: \"bd-customcss-innerpane\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n className: \"editor-wrapper\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n id: \"bd-customcss-editor-detached\",\n className: \"editor\",\n ref: \"editor\"\n }, self.css)), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n id: \"bd-customcss-attach-controls\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"ul\", {\n className: \"checkbox-group\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(_checkbox__WEBPACK_IMPORTED_MODULE_5__[\"default\"], {\n id: \"live-update\",\n text: \"Live Update\",\n onChange: self.onChange,\n checked: _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-css-0\"]\n })), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"div\", {\n id: \"bd-customcss-detach-controls-button\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"button\", {\n style: {\n borderRadius: \"3px 0 0 3px\",\n borderRight: \"1px solid #3f4146\"\n },\n className: \"btn btn-primary\",\n onClick: () => {\n self.onClick(\"update\");\n }\n }, \"Update\"), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"button\", {\n style: {\n borderRadius: \"0\",\n borderLeft: \"1px solid #2d2d2d\",\n borderRight: \"1px solid #2d2d2d\"\n },\n className: \"btn btn-primary\",\n onClick: () => {\n self.onClick(\"save\");\n }\n }, \"Save\"), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"button\", {\n style: {\n borderRadius: \"0 3px 3px 0\",\n borderLeft: \"1px solid #3f4146\"\n },\n className: \"btn btn-primary\",\n onClick: () => {\n self.onClick(\"attach\");\n }\n }, \"Attach\"), _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].react.createElement(\"span\", {\n style: {\n fontSize: \"10px\",\n marginLeft: \"5px\"\n }\n }, \"Unsaved changes are lost on attach\")))));\n }\n\n onChange(id, checked) {\n switch (id) {\n case \"live-update\":\n _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][\"bda-css-0\"] = checked;\n _modules_settingsPanel__WEBPACK_IMPORTED_MODULE_1__[\"default\"].saveSettings();\n break;\n }\n }\n\n onClick(id) {\n const self = this;\n\n switch (id) {\n case \"attach\":\n if (_modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].query(\"#editor-detached\")) self.props.attach();\n _modules_v2__WEBPACK_IMPORTED_MODULE_2__[\"default\"].reactDom.unmountComponentAtNode(self.root);\n self.root.remove();\n break;\n\n case \"update\":\n self.updateCss();\n break;\n\n case \"save\":\n self.saveCss();\n break;\n }\n }\n\n updateCss() {\n _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].removeStyle(\"customcss\");\n _modules_domtools__WEBPACK_IMPORTED_MODULE_4__[\"default\"].addStyle(\"customcss\", this.editor.session.getValue());\n }\n\n saveCss() {\n _modules_dataStore__WEBPACK_IMPORTED_MODULE_3__[\"default\"].setBDData(\"bdcustomcss\", btoa(this.editor.session.getValue()));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/ui/cssEditorDetached.js.js","sources":["webpack://BetterDiscord/./src/ui/cssEditorDetached.js?0d02"],"sourcesContent":["import { settingsCookie } from \"../0globals\";\nimport Settings from \"../modules/settingsPanel\";\nimport BDV2 from \"../modules/v2\";\nimport DataStore from \"../modules/dataStore\";\nimport DOM from \"../modules/domtools\";\nimport Checkbox from \"./checkbox\";\nexport default class V2C_CssEditorDetached extends BDV2.reactComponent {\n  constructor(props) {\n    super(props);\n    const self = this;\n    self.onClick = self.onClick.bind(self);\n    self.updateCss = self.updateCss.bind(self);\n    self.saveCss = self.saveCss.bind(self);\n    self.onChange = self.onChange.bind(self);\n  }\n\n  componentDidMount() {\n    DOM.addClass(DOM.query(\"#app-mount\"), \"bd-detached-editor\");\n    BDV2.editorDetached = true; // this.updateLineCount();\n\n    this.editor = ace.edit(\"bd-customcss-editor-detached\");\n    this.editor.setTheme(\"ace/theme/monokai\");\n    this.editor.session.setMode(\"ace/mode/css\");\n    this.editor.setShowPrintMargin(false);\n    this.editor.setFontSize(14);\n    this.editor.on(\"change\", () => {\n      if (!settingsCookie[\"bda-css-0\"]) return;\n      this.saveCss();\n      this.updateCss();\n    });\n  }\n\n  componentWillUnmount() {\n    DOM.removeClass(DOM.query(\"#app-mount\"), \"bd-detached-editor\");\n    BDV2.editorDetached = false;\n    this.editor.destroy();\n  }\n\n  updateLineCount() {\n    const lineCount = this.refs.editor.value.split(\"\\n\").length;\n    if (lineCount == this.props.lines) return;\n    this.refs.lines.textContent = Array.from(new Array(lineCount), (_, i) => i + 1).join(\".\\n\") + \".\";\n    this.props.lines = lineCount;\n  }\n\n  get options() {\n    return {\n      lineNumbers: true,\n      mode: \"css\",\n      indentUnit: 4,\n      theme: \"material\",\n      scrollbarStyle: \"simple\"\n    };\n  }\n\n  get css() {\n    const _ccss = DataStore.getBDData(\"bdcustomcss\");\n\n    let ccss = \"\";\n\n    if (_ccss && _ccss !== \"\") {\n      ccss = atob(_ccss);\n    }\n\n    return ccss;\n  }\n\n  get root() {\n    const _root = DOM.query(\"#bd-customcss-detach-container\");\n\n    if (!_root) {\n      if (!this.injectRoot()) return null;\n      return this.detachedRoot;\n    }\n\n    return _root;\n  }\n\n  injectRoot() {\n    const app = DOM.query(\".app, .\" + BDModules.get(e => e.app && e.layers)[0].app.split(\" \")[0]);\n    if (!app) return false;\n    DOM.insertAfter(DOM.createElement(`<div id=\"bd-customcss-detach-container\">`), app);\n    return true;\n  }\n\n  render() {\n    const self = this;\n    return BDV2.react.createElement(\"div\", {\n      className: \"bd-detached-css-editor\",\n      id: \"bd-customcss-detach-editor\"\n    }, BDV2.react.createElement(\"div\", {\n      id: \"bd-customcss-innerpane\"\n    }, BDV2.react.createElement(\"div\", {\n      className: \"editor-wrapper\"\n    }, BDV2.react.createElement(\"div\", {\n      id: \"bd-customcss-editor-detached\",\n      className: \"editor\",\n      ref: \"editor\"\n    }, self.css)), BDV2.react.createElement(\"div\", {\n      id: \"bd-customcss-attach-controls\"\n    }, BDV2.react.createElement(\"ul\", {\n      className: \"checkbox-group\"\n    }, BDV2.react.createElement(Checkbox, {\n      id: \"live-update\",\n      text: \"Live Update\",\n      onChange: self.onChange,\n      checked: settingsCookie[\"bda-css-0\"]\n    })), BDV2.react.createElement(\"div\", {\n      id: \"bd-customcss-detach-controls-button\"\n    }, BDV2.react.createElement(\"button\", {\n      style: {\n        borderRadius: \"3px 0 0 3px\",\n        borderRight: \"1px solid #3f4146\"\n      },\n      className: \"btn btn-primary\",\n      onClick: () => {\n        self.onClick(\"update\");\n      }\n    }, \"Update\"), BDV2.react.createElement(\"button\", {\n      style: {\n        borderRadius: \"0\",\n        borderLeft: \"1px solid #2d2d2d\",\n        borderRight: \"1px solid #2d2d2d\"\n      },\n      className: \"btn btn-primary\",\n      onClick: () => {\n        self.onClick(\"save\");\n      }\n    }, \"Save\"), BDV2.react.createElement(\"button\", {\n      style: {\n        borderRadius: \"0 3px 3px 0\",\n        borderLeft: \"1px solid #3f4146\"\n      },\n      className: \"btn btn-primary\",\n      onClick: () => {\n        self.onClick(\"attach\");\n      }\n    }, \"Attach\"), BDV2.react.createElement(\"span\", {\n      style: {\n        fontSize: \"10px\",\n        marginLeft: \"5px\"\n      }\n    }, \"Unsaved changes are lost on attach\")))));\n  }\n\n  onChange(id, checked) {\n    switch (id) {\n      case \"live-update\":\n        settingsCookie[\"bda-css-0\"] = checked;\n        Settings.saveSettings();\n        break;\n    }\n  }\n\n  onClick(id) {\n    const self = this;\n\n    switch (id) {\n      case \"attach\":\n        if (DOM.query(\"#editor-detached\")) self.props.attach();\n        BDV2.reactDom.unmountComponentAtNode(self.root);\n        self.root.remove();\n        break;\n\n      case \"update\":\n        self.updateCss();\n        break;\n\n      case \"save\":\n        self.saveCss();\n        break;\n    }\n  }\n\n  updateCss() {\n    DOM.removeStyle(\"customcss\");\n    DOM.addStyle(\"customcss\", this.editor.session.getValue());\n  }\n\n  saveCss() {\n    DataStore.setBDData(\"bdcustomcss\", btoa(this.editor.session.getValue()));\n  }\n\n}"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/ui/cssEditorDetached.js\n"); + +/***/ }), + +/***/ "./src/ui/errorBoundary.js": +/*!*********************************!*\ + !*** ./src/ui/errorBoundary.js ***! + \*********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return BDErrorBoundary; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass BDErrorBoundary extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n this.state = {\n hasError: false\n };\n }\n\n componentDidCatch() {\n this.setState({\n hasError: true\n });\n }\n\n render() {\n if (this.state.hasError) return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"react-error\"\n }, \"Component Error\");\n return this.props.children;\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvZXJyb3JCb3VuZGFyeS5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvZXJyb3JCb3VuZGFyeS5qcz82Y2RhIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi9tb2R1bGVzL3YyXCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBCREVycm9yQm91bmRhcnkgZXh0ZW5kcyBCRFYyLnJlYWN0Q29tcG9uZW50IHtcbiAgY29uc3RydWN0b3IocHJvcHMpIHtcbiAgICBzdXBlcihwcm9wcyk7XG4gICAgdGhpcy5zdGF0ZSA9IHtcbiAgICAgIGhhc0Vycm9yOiBmYWxzZVxuICAgIH07XG4gIH1cblxuICBjb21wb25lbnREaWRDYXRjaCgpIHtcbiAgICB0aGlzLnNldFN0YXRlKHtcbiAgICAgIGhhc0Vycm9yOiB0cnVlXG4gICAgfSk7XG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgaWYgKHRoaXMuc3RhdGUuaGFzRXJyb3IpIHJldHVybiBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcInJlYWN0LWVycm9yXCJcbiAgICB9LCBcIkNvbXBvbmVudCBFcnJvclwiKTtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy5jaGlsZHJlbjtcbiAgfVxuXG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/ui/errorBoundary.js\n"); + +/***/ }), + +/***/ "./src/ui/icons/delete.jsx": +/*!*********************************!*\ + !*** ./src/ui/icons/delete.jsx ***! + \*********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Delete; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n\nconst React = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].React;\nclass Delete extends React.Component {\n render() {\n const size = this.props.size || \"24px\";\n return React.createElement(\"svg\", {\n className: this.props.className || \"\",\n fill: \"#FFFFFF\",\n viewBox: \"0 0 24 24\",\n style: {\n width: size,\n height: size\n },\n onClick: this.props.onClick\n }, React.createElement(\"path\", {\n fill: \"none\",\n d: \"M0 0h24v24H0V0z\"\n }), React.createElement(\"path\", {\n d: \"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zm2.46-7.12l1.41-1.41L12 12.59l2.12-2.12 1.41 1.41L13.41 14l2.12 2.12-1.41 1.41L12 15.41l-2.12 2.12-1.41-1.41L10.59 14l-2.13-2.12zM15.5 4l-1-1h-5l-1 1H5v2h14V4z\"\n }), React.createElement(\"path\", {\n fill: \"none\",\n d: \"M0 0h24v24H0z\"\n }));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvaWNvbnMvZGVsZXRlLmpzeC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvaWNvbnMvZGVsZXRlLmpzeD8yYWE5Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi8uLi9tb2R1bGVzL3YyXCI7XG5jb25zdCBSZWFjdCA9IEJEVjIuUmVhY3Q7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBEZWxldGUgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICByZW5kZXIoKSB7XG4gICAgY29uc3Qgc2l6ZSA9IHRoaXMucHJvcHMuc2l6ZSB8fCBcIjI0cHhcIjtcbiAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChcInN2Z1wiLCB7XG4gICAgICBjbGFzc05hbWU6IHRoaXMucHJvcHMuY2xhc3NOYW1lIHx8IFwiXCIsXG4gICAgICBmaWxsOiBcIiNGRkZGRkZcIixcbiAgICAgIHZpZXdCb3g6IFwiMCAwIDI0IDI0XCIsXG4gICAgICBzdHlsZToge1xuICAgICAgICB3aWR0aDogc2l6ZSxcbiAgICAgICAgaGVpZ2h0OiBzaXplXG4gICAgICB9LFxuICAgICAgb25DbGljazogdGhpcy5wcm9wcy5vbkNsaWNrXG4gICAgfSwgUmVhY3QuY3JlYXRlRWxlbWVudChcInBhdGhcIiwge1xuICAgICAgZmlsbDogXCJub25lXCIsXG4gICAgICBkOiBcIk0wIDBoMjR2MjRIMFYwelwiXG4gICAgfSksIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJwYXRoXCIsIHtcbiAgICAgIGQ6IFwiTTYgMTljMCAxLjEuOSAyIDIgMmg4YzEuMSAwIDItLjkgMi0yVjdINnYxMnptMi40Ni03LjEybDEuNDEtMS40MUwxMiAxMi41OWwyLjEyLTIuMTIgMS40MSAxLjQxTDEzLjQxIDE0bDIuMTIgMi4xMi0xLjQxIDEuNDFMMTIgMTUuNDFsLTIuMTIgMi4xMi0xLjQxLTEuNDFMMTAuNTkgMTRsLTIuMTMtMi4xMnpNMTUuNSA0bC0xLTFoLTVsLTEgMUg1djJoMTRWNHpcIlxuICAgIH0pLCBSZWFjdC5jcmVhdGVFbGVtZW50KFwicGF0aFwiLCB7XG4gICAgICBmaWxsOiBcIm5vbmVcIixcbiAgICAgIGQ6IFwiTTAgMGgyNHYyNEgwelwiXG4gICAgfSkpO1xuICB9XG5cbn0iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/icons/delete.jsx\n"); + +/***/ }), + +/***/ "./src/ui/icons/downarrow.jsx": +/*!************************************!*\ + !*** ./src/ui/icons/downarrow.jsx ***! + \************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return DownArrow; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n\nconst React = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].React;\nclass DownArrow extends React.Component {\n render() {\n const size = this.props.size || \"16px\";\n return React.createElement(\"svg\", {\n className: this.props.className || \"\",\n fill: \"#FFFFFF\",\n viewBox: \"0 0 24 24\",\n style: {\n width: size,\n height: size\n }\n }, React.createElement(\"path\", {\n d: \"M8.12 9.29L12 13.17l3.88-3.88c.39-.39 1.02-.39 1.41 0 .39.39.39 1.02 0 1.41l-4.59 4.59c-.39.39-1.02.39-1.41 0L6.7 10.7c-.39-.39-.39-1.02 0-1.41.39-.38 1.03-.39 1.42 0z\"\n }));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvaWNvbnMvZG93bmFycm93LmpzeC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvaWNvbnMvZG93bmFycm93LmpzeD9hMTcxIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi8uLi9tb2R1bGVzL3YyXCI7XG5jb25zdCBSZWFjdCA9IEJEVjIuUmVhY3Q7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBEb3duQXJyb3cgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICByZW5kZXIoKSB7XG4gICAgY29uc3Qgc2l6ZSA9IHRoaXMucHJvcHMuc2l6ZSB8fCBcIjE2cHhcIjtcbiAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChcInN2Z1wiLCB7XG4gICAgICBjbGFzc05hbWU6IHRoaXMucHJvcHMuY2xhc3NOYW1lIHx8IFwiXCIsXG4gICAgICBmaWxsOiBcIiNGRkZGRkZcIixcbiAgICAgIHZpZXdCb3g6IFwiMCAwIDI0IDI0XCIsXG4gICAgICBzdHlsZToge1xuICAgICAgICB3aWR0aDogc2l6ZSxcbiAgICAgICAgaGVpZ2h0OiBzaXplXG4gICAgICB9XG4gICAgfSwgUmVhY3QuY3JlYXRlRWxlbWVudChcInBhdGhcIiwge1xuICAgICAgZDogXCJNOC4xMiA5LjI5TDEyIDEzLjE3bDMuODgtMy44OGMuMzktLjM5IDEuMDItLjM5IDEuNDEgMCAuMzkuMzkuMzkgMS4wMiAwIDEuNDFsLTQuNTkgNC41OWMtLjM5LjM5LTEuMDIuMzktMS40MSAwTDYuNyAxMC43Yy0uMzktLjM5LS4zOS0xLjAyIDAtMS40MS4zOS0uMzggMS4wMy0uMzkgMS40MiAwelwiXG4gICAgfSkpO1xuICB9XG5cbn0iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/ui/icons/downarrow.jsx\n"); + +/***/ }), + +/***/ "./src/ui/icons/edit.jsx": +/*!*******************************!*\ + !*** ./src/ui/icons/edit.jsx ***! + \*******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Edit; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n\nconst React = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].React;\nclass Edit extends React.Component {\n render() {\n const size = this.props.size || \"24px\";\n return React.createElement(\"svg\", {\n className: this.props.className || \"\",\n viewBox: \"0 0 24 24\",\n fill: \"#FFFFFF\",\n style: {\n width: size,\n height: size\n },\n onClick: this.props.onClick\n }, React.createElement(\"path\", {\n d: \"M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34c-.39-.39-1.02-.39-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z\"\n }), React.createElement(\"path\", {\n d: \"M0 0h24v24H0z\",\n fill: \"none\"\n }));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvaWNvbnMvZWRpdC5qc3guanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL3VpL2ljb25zL2VkaXQuanN4PzNiNDciXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJEVjIgZnJvbSBcIi4uLy4uL21vZHVsZXMvdjJcIjtcbmNvbnN0IFJlYWN0ID0gQkRWMi5SZWFjdDtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEVkaXQgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICByZW5kZXIoKSB7XG4gICAgY29uc3Qgc2l6ZSA9IHRoaXMucHJvcHMuc2l6ZSB8fCBcIjI0cHhcIjtcbiAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChcInN2Z1wiLCB7XG4gICAgICBjbGFzc05hbWU6IHRoaXMucHJvcHMuY2xhc3NOYW1lIHx8IFwiXCIsXG4gICAgICB2aWV3Qm94OiBcIjAgMCAyNCAyNFwiLFxuICAgICAgZmlsbDogXCIjRkZGRkZGXCIsXG4gICAgICBzdHlsZToge1xuICAgICAgICB3aWR0aDogc2l6ZSxcbiAgICAgICAgaGVpZ2h0OiBzaXplXG4gICAgICB9LFxuICAgICAgb25DbGljazogdGhpcy5wcm9wcy5vbkNsaWNrXG4gICAgfSwgUmVhY3QuY3JlYXRlRWxlbWVudChcInBhdGhcIiwge1xuICAgICAgZDogXCJNMyAxNy4yNVYyMWgzLjc1TDE3LjgxIDkuOTRsLTMuNzUtMy43NUwzIDE3LjI1ek0yMC43MSA3LjA0Yy4zOS0uMzkuMzktMS4wMiAwLTEuNDFsLTIuMzQtMi4zNGMtLjM5LS4zOS0xLjAyLS4zOS0xLjQxIDBsLTEuODMgMS44MyAzLjc1IDMuNzUgMS44My0xLjgzelwiXG4gICAgfSksIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJwYXRoXCIsIHtcbiAgICAgIGQ6IFwiTTAgMGgyNHYyNEgwelwiLFxuICAgICAgZmlsbDogXCJub25lXCJcbiAgICB9KSk7XG4gIH1cblxufSJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/icons/edit.jsx\n"); + +/***/ }), + +/***/ "./src/ui/icons/history.jsx": +/*!**********************************!*\ + !*** ./src/ui/icons/history.jsx ***! + \**********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return History; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n{\n /* \r\n \r\n \r\n */\n}\n\nconst React = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].React;\nclass History extends React.Component {\n render() {\n const size = this.props.size || \"18px\";\n return React.createElement(\"svg\", {\n viewBox: \"0 0 24 24\",\n fill: \"#FFFFFF\",\n className: this.props.className || \"\",\n style: {\n width: size,\n height: size\n },\n onClick: this.props.onClick\n }, React.createElement(\"path\", {\n d: \"M0 0h24v24H0z\",\n fill: \"none\"\n }), React.createElement(\"path\", {\n d: \"M13 3c-4.97 0-9 4.03-9 9H1l3.89 3.89.07.14L9 12H6c0-3.87 3.13-7 7-7s7 3.13 7 7-3.13 7-7 7c-1.93 0-3.68-.79-4.94-2.06l-1.42 1.42C8.27 19.99 10.51 21 13 21c4.97 0 9-4.03 9-9s-4.03-9-9-9zm-1 5v5l4.28 2.54.72-1.21-3.5-2.08V8H12z\"\n }));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvaWNvbnMvaGlzdG9yeS5qc3guanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL3VpL2ljb25zL2hpc3RvcnkuanN4PzgzNzEiXSwic291cmNlc0NvbnRlbnQiOlsie1xuICAvKiA8c3ZnIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB2aWV3Qm94PVwiMCAwIDI0IDI0XCIgZmlsbD1cIndoaXRlXCIgd2lkdGg9XCIxOHB4XCIgaGVpZ2h0PVwiMThweFwiPlxyXG4gICAgIDxwYXRoIGQ9XCJNMCAwaDI0djI0SDB6XCIgZmlsbD1cIm5vbmVcIi8+XHJcbiAgICAgPHBhdGggZD1cIk0xMyAzYy00Ljk3IDAtOSA0LjAzLTkgOUgxbDMuODkgMy44OS4wNy4xNEw5IDEySDZjMC0zLjg3IDMuMTMtNyA3LTdzNyAzLjEzIDcgNy0zLjEzIDctNyA3Yy0xLjkzIDAtMy42OC0uNzktNC45NC0yLjA2bC0xLjQyIDEuNDJDOC4yNyAxOS45OSAxMC41MSAyMSAxMyAyMWM0Ljk3IDAgOS00LjAzIDktOXMtNC4wMy05LTktOXptLTEgNXY1bDQuMjggMi41NC43Mi0xLjIxLTMuNS0yLjA4VjhIMTJ6XCIvPlxyXG4gIDwvc3ZnPiAqL1xufVxuaW1wb3J0IEJEVjIgZnJvbSBcIi4uLy4uL21vZHVsZXMvdjJcIjtcbmNvbnN0IFJlYWN0ID0gQkRWMi5SZWFjdDtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEhpc3RvcnkgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICByZW5kZXIoKSB7XG4gICAgY29uc3Qgc2l6ZSA9IHRoaXMucHJvcHMuc2l6ZSB8fCBcIjE4cHhcIjtcbiAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChcInN2Z1wiLCB7XG4gICAgICB2aWV3Qm94OiBcIjAgMCAyNCAyNFwiLFxuICAgICAgZmlsbDogXCIjRkZGRkZGXCIsXG4gICAgICBjbGFzc05hbWU6IHRoaXMucHJvcHMuY2xhc3NOYW1lIHx8IFwiXCIsXG4gICAgICBzdHlsZToge1xuICAgICAgICB3aWR0aDogc2l6ZSxcbiAgICAgICAgaGVpZ2h0OiBzaXplXG4gICAgICB9LFxuICAgICAgb25DbGljazogdGhpcy5wcm9wcy5vbkNsaWNrXG4gICAgfSwgUmVhY3QuY3JlYXRlRWxlbWVudChcInBhdGhcIiwge1xuICAgICAgZDogXCJNMCAwaDI0djI0SDB6XCIsXG4gICAgICBmaWxsOiBcIm5vbmVcIlxuICAgIH0pLCBSZWFjdC5jcmVhdGVFbGVtZW50KFwicGF0aFwiLCB7XG4gICAgICBkOiBcIk0xMyAzYy00Ljk3IDAtOSA0LjAzLTkgOUgxbDMuODkgMy44OS4wNy4xNEw5IDEySDZjMC0zLjg3IDMuMTMtNyA3LTdzNyAzLjEzIDcgNy0zLjEzIDctNyA3Yy0xLjkzIDAtMy42OC0uNzktNC45NC0yLjA2bC0xLjQyIDEuNDJDOC4yNyAxOS45OSAxMC41MSAyMSAxMyAyMWM0Ljk3IDAgOS00LjAzIDktOXMtNC4wMy05LTktOXptLTEgNXY1bDQuMjggMi41NC43Mi0xLjIxLTMuNS0yLjA4VjhIMTJ6XCJcbiAgICB9KSk7XG4gIH1cblxufSJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/icons/history.jsx\n"); + +/***/ }), + +/***/ "./src/ui/icons/search.jsx": +/*!*********************************!*\ + !*** ./src/ui/icons/search.jsx ***! + \*********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Search; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n\nconst React = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].React;\nclass Search extends React.Component {\n render() {\n const size = this.props.size || \"16px\";\n return React.createElement(\"svg\", {\n className: this.props.className || \"\",\n fill: \"#FFFFFF\",\n viewBox: \"0 0 24 24\",\n style: {\n width: size,\n height: size\n }\n }, React.createElement(\"path\", {\n fill: \"none\",\n d: \"M0 0h24v24H0V0z\"\n }), React.createElement(\"path\", {\n d: \"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z\"\n }));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvaWNvbnMvc2VhcmNoLmpzeC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvaWNvbnMvc2VhcmNoLmpzeD9jM2E5Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi8uLi9tb2R1bGVzL3YyXCI7XG5jb25zdCBSZWFjdCA9IEJEVjIuUmVhY3Q7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBTZWFyY2ggZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICByZW5kZXIoKSB7XG4gICAgY29uc3Qgc2l6ZSA9IHRoaXMucHJvcHMuc2l6ZSB8fCBcIjE2cHhcIjtcbiAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChcInN2Z1wiLCB7XG4gICAgICBjbGFzc05hbWU6IHRoaXMucHJvcHMuY2xhc3NOYW1lIHx8IFwiXCIsXG4gICAgICBmaWxsOiBcIiNGRkZGRkZcIixcbiAgICAgIHZpZXdCb3g6IFwiMCAwIDI0IDI0XCIsXG4gICAgICBzdHlsZToge1xuICAgICAgICB3aWR0aDogc2l6ZSxcbiAgICAgICAgaGVpZ2h0OiBzaXplXG4gICAgICB9XG4gICAgfSwgUmVhY3QuY3JlYXRlRWxlbWVudChcInBhdGhcIiwge1xuICAgICAgZmlsbDogXCJub25lXCIsXG4gICAgICBkOiBcIk0wIDBoMjR2MjRIMFYwelwiXG4gICAgfSksIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJwYXRoXCIsIHtcbiAgICAgIGQ6IFwiTTE1LjUgMTRoLS43OWwtLjI4LS4yN0MxNS40MSAxMi41OSAxNiAxMS4xMSAxNiA5LjUgMTYgNS45MSAxMy4wOSAzIDkuNSAzUzMgNS45MSAzIDkuNSA1LjkxIDE2IDkuNSAxNmMxLjYxIDAgMy4wOS0uNTkgNC4yMy0xLjU3bC4yNy4yOHYuNzlsNSA0Ljk5TDIwLjQ5IDE5bC00Ljk5LTV6bS02IDBDNy4wMSAxNCA1IDExLjk5IDUgOS41UzcuMDEgNSA5LjUgNSAxNCA3LjAxIDE0IDkuNSAxMS45OSAxNCA5LjUgMTR6XCJcbiAgICB9KSk7XG4gIH1cblxufSJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/icons/search.jsx\n"); + +/***/ }), + +/***/ "./src/ui/lightcordLogo.js": +/*!*********************************!*\ + !*** ./src/ui/lightcordLogo.js ***! + \*********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return LightcordLogo; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass LightcordLogo extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n render() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"svg\", {\n height: \"100%\",\n width: this.props.size,\n className: \"bd-logo \" + this.props.className,\n style: {\n fillRule: \"evenodd\",\n clipRule: \"evenodd\",\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\"\n },\n viewBox: \"0 0 168 190\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"metadata\", null), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"rect\", {\n x: \"14.9\",\n y: \"35.3\",\n className: \"st0\",\n width: \"139.2\",\n height: \"97.7\",\n fill: \"#FFFFFF\"\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"defs\", null, ...[_modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"linearGradient\", {\n id: \"SVGID_1_\",\n gradientUnits: \"userSpaceOnUse\",\n x1: \"66.7\",\n y1: \"112.3\",\n x2: \"66.7\",\n y2: \"91.2685\",\n gradientTransform: \"matrix(1 0 0 -1 0 192)\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"stop\", {\n offset: \"0\",\n style: {\n stopColor: \"#E20613\"\n }\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"stop\", {\n offset: \"1\",\n style: {\n stopColor: \"#731A14\"\n }\n })), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"linearGradient\", {\n id: \"SVGID_2_\",\n gradientUnits: \"userSpaceOnUse\",\n x1: \"101.7\",\n y1: \"112.3\",\n x2: \"101.7\",\n y2: \"91.2685\",\n gradientTransform: \"matrix(1 0 0 -1 0 192)\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"stop\", {\n offset: \"0\",\n style: {\n stopColor: \"#E20613\"\n }\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"stop\", {\n offset: \"1\",\n style: {\n stopColor: \"#731A13\"\n }\n })), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"linearGradient\", {\n id: \"SVGID_3_\",\n gradientUnits: \"userSpaceOnUse\",\n x1: \"84\",\n y1: \"192\",\n x2: \"84\",\n y2: \"2\",\n gradientTransform: \"matrix(1 0 0 -1 0 192)\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"stop\", {\n offset: \"0\",\n style: {\n stopColor: \"#E30613\"\n }\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"stop\", {\n offset: \"1\",\n style: {\n stopColor: \"#731A13\"\n }\n }))]), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"g\", null, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"path\", {\n className: \"st1\",\n d: \"M66.7,79.7c-5.4,0-9.8,4.7-9.8,10.5s4.4,10.5,9.8,10.5s9.8-4.7,9.8-10.5C76.5,84.4,72.1,79.7,66.7,79.7z\",\n fill: \"url(#SVGID_1_)\",\n opacity: \"1\"\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"path\", {\n className: \"st2\",\n d: \"M101.7,79.7c-5.4,0-9.8,4.7-9.8,10.5s4.4,10.5,9.8,10.5s9.8-4.7,9.8-10.5C111.5,84.4,107.1,79.7,101.7,79.7z\",\n fill: \"url(#SVGID_2_)\",\n opacity: \"1\"\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"path\", {\n className: \"st3\",\n d: \"M148.4,0H19.6C8.8,0,0,8.8,0,19.6V148c0,10.8,8.8,19.6,19.6,19.6h108.9l-5.1-17.5l12.3,11.3l11.6,10.7 L168,190v-41.9v-9.5v-119C168,8.8,159.2,0,148.4,0z M111.3,124.1c0,0-3.4-4.1-6.3-7.7c12.6-3.5,17.4-11.3,17.4-11.3 c-4,2.6-7.7,4.4-11.1,5.6c-4.8,2-9.5,3.3-14,4.1c-9.2,1.7-17.6,1.3-24.9-0.1c-5.5-1-10.2-2.5-14.1-4.1c-2.2-0.8-4.6-1.9-7.1-3.3 c-0.3-0.2-0.6-0.3-0.9-0.5c-0.1-0.1-0.3-0.2-0.4-0.2c-1.7-1-2.6-1.6-2.6-1.6s4.6,7.6,16.8,11.2c-2.9,3.6-6.4,7.9-6.4,7.9 c-21.2-0.6-29.3-14.5-29.3-14.5c0-30.6,13.8-55.4,13.8-55.4c13.8-10.3,26.9-10,26.9-10l1,1.1C52.8,50.3,45,57.9,45,57.9 s2.1-1.2,5.7-2.7c10.3-4.5,18.4-5.7,21.8-6c0.5-0.1,1.1-0.2,1.6-0.2c5.9-0.7,12.5-0.9,19.4-0.2c9.1,1,18.9,3.7,28.9,9.1 c0,0-7.5-7.2-23.9-12.1l1.3-1.5c0,0,13.1-0.3,26.9,10c0,0,13.8,24.8,13.8,55.4C140.6,109.6,132.5,123.5,111.3,124.1z\",\n fill: \"url(#SVGID_3_)\",\n opacity: \"1\"\n })));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvbGlnaHRjb3JkTG9nby5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvbGlnaHRjb3JkTG9nby5qcz8wYWU5Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi9tb2R1bGVzL3YyXCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBMaWdodGNvcmRMb2dvIGV4dGVuZHMgQkRWMi5yZWFjdENvbXBvbmVudCB7XG4gIHJlbmRlcigpIHtcbiAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwic3ZnXCIsIHtcbiAgICAgIGhlaWdodDogXCIxMDAlXCIsXG4gICAgICB3aWR0aDogdGhpcy5wcm9wcy5zaXplLFxuICAgICAgY2xhc3NOYW1lOiBcImJkLWxvZ28gXCIgKyB0aGlzLnByb3BzLmNsYXNzTmFtZSxcbiAgICAgIHN0eWxlOiB7XG4gICAgICAgIGZpbGxSdWxlOiBcImV2ZW5vZGRcIixcbiAgICAgICAgY2xpcFJ1bGU6IFwiZXZlbm9kZFwiLFxuICAgICAgICBzdHJva2VMaW5lY2FwOiBcInJvdW5kXCIsXG4gICAgICAgIHN0cm9rZUxpbmVqb2luOiBcInJvdW5kXCJcbiAgICAgIH0sXG4gICAgICB2aWV3Qm94OiBcIjAgMCAxNjggMTkwXCJcbiAgICB9LCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJtZXRhZGF0YVwiLCBudWxsKSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwicmVjdFwiLCB7XG4gICAgICB4OiBcIjE0LjlcIixcbiAgICAgIHk6IFwiMzUuM1wiLFxuICAgICAgY2xhc3NOYW1lOiBcInN0MFwiLFxuICAgICAgd2lkdGg6IFwiMTM5LjJcIixcbiAgICAgIGhlaWdodDogXCI5Ny43XCIsXG4gICAgICBmaWxsOiBcIiNGRkZGRkZcIlxuICAgIH0pLCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkZWZzXCIsIG51bGwsIC4uLltCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJsaW5lYXJHcmFkaWVudFwiLCB7XG4gICAgICBpZDogXCJTVkdJRF8xX1wiLFxuICAgICAgZ3JhZGllbnRVbml0czogXCJ1c2VyU3BhY2VPblVzZVwiLFxuICAgICAgeDE6IFwiNjYuN1wiLFxuICAgICAgeTE6IFwiMTEyLjNcIixcbiAgICAgIHgyOiBcIjY2LjdcIixcbiAgICAgIHkyOiBcIjkxLjI2ODVcIixcbiAgICAgIGdyYWRpZW50VHJhbnNmb3JtOiBcIm1hdHJpeCgxIDAgMCAtMSAwIDE5MilcIlxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcInN0b3BcIiwge1xuICAgICAgb2Zmc2V0OiBcIjBcIixcbiAgICAgIHN0eWxlOiB7XG4gICAgICAgIHN0b3BDb2xvcjogXCIjRTIwNjEzXCJcbiAgICAgIH1cbiAgICB9KSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwic3RvcFwiLCB7XG4gICAgICBvZmZzZXQ6IFwiMVwiLFxuICAgICAgc3R5bGU6IHtcbiAgICAgICAgc3RvcENvbG9yOiBcIiM3MzFBMTRcIlxuICAgICAgfVxuICAgIH0pKSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwibGluZWFyR3JhZGllbnRcIiwge1xuICAgICAgaWQ6IFwiU1ZHSURfMl9cIixcbiAgICAgIGdyYWRpZW50VW5pdHM6IFwidXNlclNwYWNlT25Vc2VcIixcbiAgICAgIHgxOiBcIjEwMS43XCIsXG4gICAgICB5MTogXCIxMTIuM1wiLFxuICAgICAgeDI6IFwiMTAxLjdcIixcbiAgICAgIHkyOiBcIjkxLjI2ODVcIixcbiAgICAgIGdyYWRpZW50VHJhbnNmb3JtOiBcIm1hdHJpeCgxIDAgMCAtMSAwIDE5MilcIlxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcInN0b3BcIiwge1xuICAgICAgb2Zmc2V0OiBcIjBcIixcbiAgICAgIHN0eWxlOiB7XG4gICAgICAgIHN0b3BDb2xvcjogXCIjRTIwNjEzXCJcbiAgICAgIH1cbiAgICB9KSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwic3RvcFwiLCB7XG4gICAgICBvZmZzZXQ6IFwiMVwiLFxuICAgICAgc3R5bGU6IHtcbiAgICAgICAgc3RvcENvbG9yOiBcIiM3MzFBMTNcIlxuICAgICAgfVxuICAgIH0pKSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwibGluZWFyR3JhZGllbnRcIiwge1xuICAgICAgaWQ6IFwiU1ZHSURfM19cIixcbiAgICAgIGdyYWRpZW50VW5pdHM6IFwidXNlclNwYWNlT25Vc2VcIixcbiAgICAgIHgxOiBcIjg0XCIsXG4gICAgICB5MTogXCIxOTJcIixcbiAgICAgIHgyOiBcIjg0XCIsXG4gICAgICB5MjogXCIyXCIsXG4gICAgICBncmFkaWVudFRyYW5zZm9ybTogXCJtYXRyaXgoMSAwIDAgLTEgMCAxOTIpXCJcbiAgICB9LCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJzdG9wXCIsIHtcbiAgICAgIG9mZnNldDogXCIwXCIsXG4gICAgICBzdHlsZToge1xuICAgICAgICBzdG9wQ29sb3I6IFwiI0UzMDYxM1wiXG4gICAgICB9XG4gICAgfSksIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcInN0b3BcIiwge1xuICAgICAgb2Zmc2V0OiBcIjFcIixcbiAgICAgIHN0eWxlOiB7XG4gICAgICAgIHN0b3BDb2xvcjogXCIjNzMxQTEzXCJcbiAgICAgIH1cbiAgICB9KSldKSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZ1wiLCBudWxsLCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJwYXRoXCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJzdDFcIixcbiAgICAgIGQ6IFwiTTY2LjcsNzkuN2MtNS40LDAtOS44LDQuNy05LjgsMTAuNXM0LjQsMTAuNSw5LjgsMTAuNXM5LjgtNC43LDkuOC0xMC41Qzc2LjUsODQuNCw3Mi4xLDc5LjcsNjYuNyw3OS43elwiLFxuICAgICAgZmlsbDogXCJ1cmwoI1NWR0lEXzFfKVwiLFxuICAgICAgb3BhY2l0eTogXCIxXCJcbiAgICB9KSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwicGF0aFwiLCB7XG4gICAgICBjbGFzc05hbWU6IFwic3QyXCIsXG4gICAgICBkOiBcIk0xMDEuNyw3OS43Yy01LjQsMC05LjgsNC43LTkuOCwxMC41czQuNCwxMC41LDkuOCwxMC41czkuOC00LjcsOS44LTEwLjVDMTExLjUsODQuNCwxMDcuMSw3OS43LDEwMS43LDc5Ljd6XCIsXG4gICAgICBmaWxsOiBcInVybCgjU1ZHSURfMl8pXCIsXG4gICAgICBvcGFjaXR5OiBcIjFcIlxuICAgIH0pLCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJwYXRoXCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJzdDNcIixcbiAgICAgIGQ6IFwiTTE0OC40LDBIMTkuNkM4LjgsMCwwLDguOCwwLDE5LjZWMTQ4YzAsMTAuOCw4LjgsMTkuNiwxOS42LDE5LjZoMTA4LjlsLTUuMS0xNy41bDEyLjMsMTEuM2wxMS42LDEwLjcgTDE2OCwxOTB2LTQxLjl2LTkuNXYtMTE5QzE2OCw4LjgsMTU5LjIsMCwxNDguNCwweiBNMTExLjMsMTI0LjFjMCwwLTMuNC00LjEtNi4zLTcuN2MxMi42LTMuNSwxNy40LTExLjMsMTcuNC0xMS4zIGMtNCwyLjYtNy43LDQuNC0xMS4xLDUuNmMtNC44LDItOS41LDMuMy0xNCw0LjFjLTkuMiwxLjctMTcuNiwxLjMtMjQuOS0wLjFjLTUuNS0xLTEwLjItMi41LTE0LjEtNC4xYy0yLjItMC44LTQuNi0xLjktNy4xLTMuMyBjLTAuMy0wLjItMC42LTAuMy0wLjktMC41Yy0wLjEtMC4xLTAuMy0wLjItMC40LTAuMmMtMS43LTEtMi42LTEuNi0yLjYtMS42czQuNiw3LjYsMTYuOCwxMS4yYy0yLjksMy42LTYuNCw3LjktNi40LDcuOSBjLTIxLjItMC42LTI5LjMtMTQuNS0yOS4zLTE0LjVjMC0zMC42LDEzLjgtNTUuNCwxMy44LTU1LjRjMTMuOC0xMC4zLDI2LjktMTAsMjYuOS0xMGwxLDEuMUM1Mi44LDUwLjMsNDUsNTcuOSw0NSw1Ny45IHMyLjEtMS4yLDUuNy0yLjdjMTAuMy00LjUsMTguNC01LjcsMjEuOC02YzAuNS0wLjEsMS4xLTAuMiwxLjYtMC4yYzUuOS0wLjcsMTIuNS0wLjksMTkuNC0wLjJjOS4xLDEsMTguOSwzLjcsMjguOSw5LjEgYzAsMC03LjUtNy4yLTIzLjktMTIuMWwxLjMtMS41YzAsMCwxMy4xLTAuMywyNi45LDEwYzAsMCwxMy44LDI0LjgsMTMuOCw1NS40QzE0MC42LDEwOS42LDEzMi41LDEyMy41LDExMS4zLDEyNC4xelwiLFxuICAgICAgZmlsbDogXCJ1cmwoI1NWR0lEXzNfKVwiLFxuICAgICAgb3BhY2l0eTogXCIxXCJcbiAgICB9KSkpO1xuICB9XG5cbn0iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/ui/lightcordLogo.js\n"); + +/***/ }), + +/***/ "./src/ui/presenceSettings.jsx": +/*!*************************************!*\ + !*** ./src/ui/presenceSettings.jsx ***! + \*************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_PresenceSettings; });\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _modules_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../modules/utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _modules_domtools__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../modules/domtools */ \"./src/modules/domtools.js\");\n/* harmony import */ var _xSvg__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./xSvg */ \"./src/ui/xSvg.js\");\n/* harmony import */ var _reloadIcon__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./reloadIcon */ \"./src/ui/reloadIcon.js\");\n/* harmony import */ var _icons_edit__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./icons/edit */ \"./src/ui/icons/edit.jsx\");\n/* harmony import */ var _icons_delete__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./icons/delete */ \"./src/ui/icons/delete.jsx\");\n/* harmony import */ var _components_switch__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./components/switch */ \"./src/ui/components/switch.jsx\");\n/* harmony import */ var _tooltipWrap__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./tooltipWrap */ \"./src/ui/tooltipWrap.js\");\n/* harmony import */ var _settingsTitle__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./settingsTitle */ \"./src/ui/settingsTitle.js\");\n/* harmony import */ var _settingsGroup__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./settingsGroup */ \"./src/ui/settingsGroup.js\");\n\n\n\n\n\n\n\n\n\n\n\n\nconst React = _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].React;\nconst anchorClasses = _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].anchorClasses;\nclass V2C_PresenceSettings extends _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n console.log(props);\n }\n\n updatePreview(data) {\n this.setState({\n data\n });\n }\n\n render() {\n let contentModule = BDModules.get(e => e.contentColumn)[0];\n return React.createElement(\"div\", {\n className: contentModule.contentColumn + \" \" + contentModule.contentColumnDefault + \" content-column default\",\n style: {\n padding: \"60px 40px 0px\"\n }\n }, React.createElement(_settingsGroup__WEBPACK_IMPORTED_MODULE_11__[\"default\"], {\n title: \"RichPresence Settings\",\n settings: this.props.settings,\n onChange: this.props.onChange\n }), React.createElement(_settingsTitle__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n text: \"RichPresence\"\n }), React.createElement(\"div\", null, RPCProps.map(e => {\n return React.createElement(PresenceSettingRow, {\n setting: e\n });\n })), React.createElement(\"div\", null, React.createElement(RpcPreview, {\n settings: this\n })));\n }\n\n}\n\nclass PresenceSettingRow extends _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reactComponent {\n render() {\n let setting = this.props.setting;\n let rowModule = BDModules.get(e => e.removeKeybind)[0];\n let marginModule = BDModules.get(e => e.marginBottom20)[0];\n let marginModule2 = BDModules.get(e => e.defaultMarginh5)[0];\n let colorModule = BDModules.get(e => e.colorStandard)[0];\n let sizeModule = BDModules.get(e => e.size32)[0];\n return React.createElement(\"div\", {\n className: rowModule.row + \" \" + marginModule.marginBottom20\n }, React.createElement(\"div\", {\n className: \"item-rJ_Cmt da-item flexChild-faoVW3 da-flexChild\"\n }, React.createElement(\"h5\", {\n className: colorModule.colorStandard + \" \" + sizeModule.size14 + \" \" + marginModule2.h5 + \" \" + marginModule2.defaultMarginh5\n }, setting.title), React.createElement(\"div\", {\n className: \"inputWrapper-31_8H8 da-inputWrapper\"\n }, React.createElement(\"input\", {\n class: \"inputDefault-_djjkz input-cIJ7To size16-1__VVI\",\n name: \"state\",\n type: \"text\",\n placeholder: \"\",\n maxlength: \"999\",\n value: setting.default\n }))), React.createElement(\"div\", {\n class: \"divider-3573oO da-divider dividerDefault-3rvLe- da-dividerDefault\"\n }));\n }\n\n}\n\nclass RpcPreview extends _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reactComponent {\n constructor(props = {}) {\n super(props);\n this.state = {\n active: \"profile\"\n };\n this.tabs = [];\n }\n\n changeTab(tab) {\n let ancientTab = this.state.active;\n if (ancientTab === tab.props.id) return;\n this.tabs.forEach(e => {\n e.setActive(false);\n });\n this.setState({\n active: tab.id\n });\n }\n\n render() {\n return React.createElement(\"div\", {\n className: \"lc-tabWrapper\"\n }, React.createElement(\"div\", {\n className: \"lc-tabnav\",\n style: {\n flex: \"0 1 auto\"\n }\n }, React.createElement(Tab, {\n onClick: this.changeTab.bind(this),\n preview: this,\n title: \"Full Profile\",\n id: \"profile\"\n }), React.createElement(Tab, {\n onClick: this.changeTab.bind(this),\n preview: this,\n title: \"User Popout\",\n id: \"popout\"\n })), React.createElement(Profile, null));\n }\n\n isActive(tab) {\n return this.state.active === tab;\n }\n /**\r\n * \r\n * @param {string} tmplate \r\n * @param {any} data \r\n */\n\n\n renderTemplate(tmplate, data) {\n Object.keys(data).forEach(k => {\n tmplate.replace(new RegExp(\"{{\" + k + \"}}\", \"g\"), data[k]);\n });\n return tmplate;\n }\n\n}\n\nclass Tab extends _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n this.state = {\n active: props.preview.isActive(props.id)\n };\n props.preview.tabs.push(this);\n }\n\n setActive(isActive) {\n this.setState({\n active: !!isActive\n });\n }\n\n render() {\n let className = `lc-navItem`;\n\n if (this.state.active) {\n className += ` lc-navItemActive`;\n } else {\n className += ` lc-navItemInactive`;\n }\n\n return React.createElement(\"div\", {\n className: className,\n onClick: () => {\n this.props.onClick(this);\n this.setActive(true);\n }\n }, this.props.title);\n }\n\n}\n\nclass Status extends _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reactComponent {\n render() {\n let status = BDModules.get(e => e.default && e.default.getPresence)[0].default.getPresence().status;\n if (status === \"invisible\") status = \"offline\";\n let className = \"pointerEvents-2zdfdO da-pointerEvents\";\n return React.createElement(\"rect\", {\n width: \"16\",\n height: \"16\",\n x: \"60\",\n y: \"60\",\n fill: \"#ffffff\",\n mask: `url(#svg-mask-status-${status})`,\n className: className\n });\n }\n\n}\n\nclass Profile extends _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].ReactComponent {\n render() {\n let user = BDModules.get(e => e.default && e.default.getCurrentUser)[0].default.getCurrentUser();\n let avatarURL = user.getAvatarURL(user.avatar.startsWith(\"a_\") ? \"gif\" : \"png\");\n let [flexModule1, stylingModule1, rootModule1, avatarModule1, nameTagModule1] = [BDModules.get(e => e.flex && e._horizontal)[0], BDModules.get(e => e.vertical && e.alignStretch)[0], BDModules.get(e => e.topSectionStreaming)[0], BDModules.get(e => e.pointerEvents)[0], BDModules.get(e => e.bot)[0]];\n return [React.createElement(\"div\", {\n className: \"lc-tab\"\n }, React.createElement(\"div\", {\n class: `${flexModule1.flex} ${stylingModule1.vertical} ${stylingModule1.justifyStart} ${stylingModule1.alignStretch} ${stylingModule1.noWrap} ${rootModule1.root}`,\n style: {\n flex: \"1 1 auto\"\n }\n }, React.createElement(\"div\", {\n class: rootModule1.topSectionPlaying\n }, React.createElement(\"header\", {\n class: rootModule1.header\n }, React.createElement(\"div\", {\n class: `${rootModule1.avatar} ${avatarModule1.wrapper}`,\n role: \"img\",\n \"aria-hidden\": \"true\",\n style: {\n width: \"80px\",\n height: \"80px\"\n }\n }, React.createElement(\"svg\", {\n width: \"92\",\n height: \"80\",\n viewBox: \"0 0 92 80\",\n class: \"mask-1l8v16 da-mask svg-2V3M55 da-svg\",\n \"aria-hidden\": \"true\"\n }, React.createElement(\"foreignObject\", {\n x: \"0\",\n y: \"0\",\n width: \"80\",\n height: \"80\",\n mask: \"url(#svg-mask-avatar-status-round-80)\"\n }, React.createElement(\"img\", {\n src: avatarURL,\n alt: \" \",\n class: avatarModule1.avatar,\n \"aria-hidden\": \"true\"\n })), React.createElement(Status, null))), React.createElement(\"div\", {\n class: `${rootModule1.headerInfo}`\n }, React.createElement(\"div\", {\n class: `${rootModule1.nameTag} ${nameTagModule1.nameTag}`\n }, React.createElement(\"span\", {\n class: `${rootModule1.username} ${rootModule1.username}`\n }, user.username), React.createElement(\"span\", {\n class: rootModule1.discriminator\n }, \"#\", user.discriminator)), React.createElement(\"div\", {\n class: `${flexModule1.flex} ${flexModule1.horizontal} ${stylingModule1.justifyStart} ${stylingModule1.alignStretch} ${stylingModule1.noWrap} ${rootModule1.profileBadges}`,\n style: {\n flex: \"1 1 auto\"\n }\n }, React.createElement(Badges, null)))), React.createElement(\"div\", {\n class: rootModule1.headerFill\n }, React.createElement(\"div\", {\n class: \"activityProfile-2bJRaP da-activityProfile activity-1ythUs da-activity\"\n }, React.createElement(\"h3\", {\n class: \"headerTextNormal-2mGWX3 headerText-1HLrL7 marginBottom8-AtZOdT da-headerTextNormal da-headerText da-marginBottom8 base-1x0h_U da-base size12-3cLvbJ\"\n }, \"En train de jouer\"), React.createElement(\"div\", {\n class: \"bodyNormal-2D39hT body-ZAhrcj flex-1O1GKY alignStart-H-X2h- da-bodyNormal da-body da-flex da-alignStart\"\n }, React.createElement(\"div\", {\n class: \"assets-VMAukC da-assets\"\n }, React.createElement(\"img\", {\n alt: \"\",\n src: \"https://cdn.discordapp.com/app-assets/708687209372581888/711293441526726747.png\",\n class: \"assetsLargeImageProfile-3YXDex assetsLargeImage-eYwpTX noUserDrag-5Mb43F da-assetsLargeImageProfile da-assetsLargeImage da-noUserDrag assetsLargeMaskProfile-1Qkfen da-assetsLargeMaskProfile\"\n }), React.createElement(\"img\", {\n alt: \"\",\n src: \"https://cdn.discordapp.com/app-assets/708687209372581888/711293441526726747.png\",\n class: \"assetsSmallImageProfile-3JcsV1 assetsSmallImage-3_3Bzj noUserDrag-5Mb43F da-assetsSmallImageProfile da-assetsSmallImage da-noUserDrag\"\n })), React.createElement(\"div\", {\n class: \"contentImagesProfile-1Mz07W content-3JfFJh da-contentImagesProfile da-content\",\n style: {\n flex: \"1 1 auto\"\n }\n }, React.createElement(\"h3\", {\n class: \"nameNormal-2lqVQK ellipsis-1XUmPN textRow-19NEd_ da-nameNormal da-ellipsis da-textRow base-1x0h_U da-base size14-e6ZScH\",\n title: \"Deroku Vanity\"\n }, React.createElement(\"span\", {\n class: \"activityName-1IaRLn da-activityName\"\n }, \"Deroku Vanity\")), React.createElement(\"div\", {\n title: \"Lightcord test\",\n class: \"details-38sfDr ellipsis-1XUmPN textRow-19NEd_ da-details da-ellipsis da-textRow\"\n }, \"Lightcord test\"), React.createElement(\"div\", {\n class: \"state-Tt0LO3 ellipsis-1XUmPN textRow-19NEd_ da-state da-ellipsis da-textRow\"\n }, React.createElement(\"span\", {\n title: \"gay comme phorcys\"\n }, \"gay comme phorcys\")), React.createElement(\"div\", {\n class: \"timestamp-VjAZmo ellipsis-1XUmPN textRow-19NEd_ da-timestamp da-ellipsis da-textRow\"\n }, \"50\\xA0min\\xA024\\xA0s \\xE9coul\\xE9es\")))))), React.createElement(\"div\", {\n class: rootModule1.body\n }, React.createElement(\"div\", {\n class: \"scrollerWrap-2lJEkd da-scrollerWrap scrollerFade-1Ijw5y da-scrollerFade\"\n }, React.createElement(\"div\", {\n class: \"scroller-2FKFPG da-scroller\"\n }, React.createElement(\"div\", {\n class: \"userInfoSection-2acyCx da-userInfoSection\"\n }, React.createElement(\"div\", {\n class: \"userInfoSectionHeader-CBvMDh da-userInfoSectionHeader\"\n }, \"Note\"), React.createElement(\"div\", {\n class: \"note-3kmerW da-note note-QfFU8y da-note\"\n }, React.createElement(\"textarea\", {\n placeholder: \"Clique pour ajouter une note\",\n maxlength: \"256\",\n autocorrect: \"off\",\n class: \"scrollbarGhostHairline-1mSOM1 scrollbar-3dvm_9 da-scrollbarGhostHairline da-scrollbar\",\n style: {\n height: \"40px\"\n },\n disabled: true\n }))), React.createElement(\"div\", {\n class: \"userInfoSection-2acyCx da-userInfoSection\"\n }, React.createElement(\"div\", {\n class: \"connectedAccounts-repVzS da-connectedAccounts\"\n }, React.createElement(\"div\", {\n class: \"flex-1xMQg5 flex-1O1GKY da-flex da-flex horizontal-1ae9ci horizontal-2EEEnY flex-1O1GKY directionRow-3v3tfG justifyStart-2NDFzi alignCenter-1dQNNs noWrap-3jynv6 connectedAccount-36nQx7 da-connectedAccount\",\n style: {\n flex: \"0 1 auto\"\n }\n }, React.createElement(\"img\", {\n alt: \"Logo Twitter\",\n class: \"connectedAccountIcon-3P3V6F da-connectedAccountIcon\",\n src: \"/assets/4662875160dc4c56954003ebda995414.png\"\n }), React.createElement(\"div\", {\n class: \"connectedAccountNameInner-1phBvE da-connectedAccountNameInner\"\n }, React.createElement(\"div\", {\n class: \"connectedAccountName-f8AEe2 da-connectedAccountName\"\n }, \"jen_wina\"), React.createElement(\"span\", null, React.createElement(\"div\", {\n class: \"flowerStarContainer-3zDVtj da-flowerStarContainer connectedAccountVerifiedIcon-3aZz_K da-connectedAccountVerifiedIcon\",\n style: {\n width: \"16px\",\n height: \"16px\"\n }\n }, React.createElement(\"svg\", {\n class: \"flowerStar-1GeTsn da-flowerStar\",\n \"aria-hidden\": \"true\",\n width: \"16\",\n height: \"16\",\n viewBox: \"0 0 16 15.2\"\n }, React.createElement(\"path\", {\n fill: \"#4f545c\",\n \"fill-rule\": \"evenodd\",\n d: \"m16 7.6c0 .79-1.28 1.38-1.52 2.09s.44 2 0 2.59-1.84.35-2.46.8-.79 1.84-1.54 2.09-1.67-.8-2.47-.8-1.75 1-2.47.8-.92-1.64-1.54-2.09-2-.18-2.46-.8.23-1.84 0-2.59-1.54-1.3-1.54-2.09 1.28-1.38 1.52-2.09-.44-2 0-2.59 1.85-.35 2.48-.8.78-1.84 1.53-2.12 1.67.83 2.47.83 1.75-1 2.47-.8.91 1.64 1.53 2.09 2 .18 2.46.8-.23 1.84 0 2.59 1.54 1.3 1.54 2.09z\"\n })), React.createElement(\"div\", {\n class: \"childContainer-1wxZNh da-childContainer\"\n }, React.createElement(\"svg\", {\n \"aria-hidden\": \"true\",\n width: \"16\",\n height: \"16\",\n viewBox: \"0 0 16 15.2\"\n }, React.createElement(\"path\", {\n d: \"M7.4,11.17,4,8.62,5,7.26l2,1.53L10.64,4l1.36,1Z\",\n fill: \"#ffffff\"\n })))))), React.createElement(\"a\", {\n class: \"anchor-3Z-8Bb da-anchor anchorUnderlineOnHover-2ESHQB da-anchorUnderlineOnHover\",\n rel: \"noreferrer noopener\",\n target: \"_blank\",\n role: \"button\",\n tabindex: \"0\"\n }, React.createElement(\"svg\", {\n class: \"connectedAccountOpenIcon-2cNbq5 da-connectedAccountOpenIcon\",\n \"aria-hidden\": \"true\",\n width: \"24\",\n height: \"24\",\n viewBox: \"0 0 24 24\"\n }, React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M10 5V3H5.375C4.06519 3 3 4.06519 3 5.375V18.625C3 19.936 4.06519 21 5.375 21H18.625C19.936 21 21 19.936 21 18.625V14H19V19H5V5H10Z\"\n }), React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M21 2.99902H14V4.99902H17.586L9.29297 13.292L10.707 14.706L19 6.41302V9.99902H21V2.99902Z\"\n }))))))))))), React.createElement(\"div\", {\n class: \"lc-fadeOverlay\"\n })];\n }\n\n}\n\nclass Badges extends _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reactComponent {\n render() {\n let user = BDModules.get(e => e.default && e.default.getCurrentUser)[0].default.getCurrentUser();\n let rootModule = BDModules.get(e => e.topSectionStreaming)[0];\n let UserFlags = BDModules.get(e => e.UserFlags)[0].UserFlags;\n let badges = [];\n let serialized = [];\n\n for (let flagName in UserFlags) {\n if (user.hasFlag(UserFlags[flagName])) serialized.push(flagName);\n }\n\n for (let flagName of serialized) {\n let searchable = `profileBadge${flagName.toLowerCase().replace(/_/g, \" \").split(\" \").map(e => e[0].toUpperCase() + e.slice(1)).join(\"\")}`;\n searchable = searchable.replace(\"HypesquadOnline\", \"HypeSquadOnline\");\n console.log(searchable, rootModule[searchable]);\n if (!rootModule[searchable]) continue;\n badges.push(React.createElement(Badge, {\n name: searchable\n }));\n }\n\n if (user.hasPremiumSubscription) {\n badges.push(React.createElement(Badge, {\n name: \"profileBadgePremium\"\n }));\n }\n\n return badges;\n }\n\n}\n\nclass Badge extends _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reactComponent {\n render() {\n let rootModule1 = BDModules.get(e => e.topSectionStreaming)[0];\n return React.createElement(\"div\", {\n class: rootModule1.profileBadgeWrapper\n }, React.createElement(\"div\", null, React.createElement(\"div\", {\n class: \"\",\n role: \"button\",\n tabindex: \"0\"\n }, React.createElement(\"div\", {\n class: `profileBadge-2BqF-Z da-profileBadge ${rootModule1[this.props.name]}`\n }))));\n }\n\n}\n\nconst RPCProps = [{\n title: \"State\",\n id: \"state\",\n default: \"Browsing Discord\",\n type: \"text\"\n}, {\n title: \"Details\",\n id: \"details\",\n default: \"Lightcord\",\n type: \"text\"\n}];\nconst Constants = {\n PresenceViewer: {\n USER_ACTIVITY_HEADER_WATCHING: \"Watching {name}\",\n USER_ACTIVITY_HEADER_PLAYING: \"Playing a game\",\n USER_ACTIVITY_STATE_SIZE: \"({count} of {max})\",\n USER_ACTIVITY_TIMESTAMP_END: \"{hours, plural, =-1 {} other {{hours}:}}{minutes, plural, =-1 {} other {{minutes}:}}{seconds, plural, =-1 {} other {{seconds}}} left\",\n USER_ACTIVITY_TIMESTAMP_START: \"{hours, plural, =-1 {} other {{hours}:}}{minutes, plural, =-1 {} other {{minutes}:}}{seconds, plural, =-1 {} other {{seconds}}} elapsed\",\n USER_ACTIVITY_ACTION_NOTIFY_ME: \"Notify Me\",\n USER_ACTIVITY_ACTION_ASK_TO_JOIN: \"Ask to Join\",\n USER_ACTIVITY_ACTION_SPECTATE: \"Spectate\",\n SECTION_TITLE: \"Rich Presence Visualizer\",\n SECTION_MORE_INFO: \"Rich Presence lets your game surface exciting game data on your players' profiles, and lets them play together with chat invites, Ask to Join, and Spectate. See exactly how your text and art will look on a user's profile.\",\n PROFILE: \"Full Profile\",\n USER_POPOUT: \"User Popout\",\n ACTIVITY_FEED: \"Games Tab\",\n NONE: \"None\",\n SHOW_CODE: \"Show Code\",\n MOBILE_ALERT: \"Rich Presence Visualizer only available on desktop\",\n PARTY_ID_MUST_BE_UNIQUE: \"Party ID can't match Join or Spectate Secrets.\",\n SECRETS_MUST_BE_UNIQUE: \"Join and Spectate Secrets must be unique strings.\"\n },\n Tooltips: {\n STATE: \"[type: char*]\\nThe user's current party status\",\n DETAILS: \"[type: char*]\\nWhat the player is currently doing\",\n START_TIMESTAMP: '[type: int64_t]\\nEpoch seconds for game start - including will show time as \"elapsed\"',\n END_TIMESTAMP: '[type: int64_t]\\nEpoch seconds for game end - including will show time as \"remaining\"\\t',\n LARGE_IMAGE_KEY: \"[type: char*]\\nKey of the uploaded image for the large profile artwork\",\n LARGE_IMAGE_TEXT: \"[type: char*]\\nTooltip for the largeImageKey\",\n SMALL_IMAGE_KEY: \"[type: char*]\\nKey of the uploaded image for the small profile artwork\",\n SMALL_IMAGE_TEXT: \"[type: char*]\\nTooltip for the smallImageKey\",\n PARTY_ID: \"[type: char*]\\nId of the player's party, lobby, or group\",\n PARTY_SIZE: \"[type: int]\\nCurrent size of the player's party, lobby, or group\",\n PARTY_MAX: \"[type: int]\\nMaximum size of the player's party, lobby, or group\\t\",\n SPECTATE_SECRET: \"[type: char*]\\nUnique hashed string for Spectate button\",\n JOIN_SECRET: \"[type: char*]\\nUnique hashed string for chat invitations and Ask to Join\"\n },\n UserProfile: {\n USER_INFO: \"User Info\",\n MUTUAL_SERVERS: \"Mutual Servers\",\n MUTUAL_FRIENDS: \"Mutual Friends\",\n NOTE: \"Note\",\n ADD_NOTE: \"Click to add note\"\n }\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/ui/presenceSettings.jsx.js","sources":["webpack://BetterDiscord/./src/ui/presenceSettings.jsx?ceef"],"sourcesContent":["import { settingsCookie } from \"../0globals\";\nimport BDV2 from \"../modules/v2\";\nimport Utils from \"../modules/utils\";\nimport DOM from \"../modules/domtools\";\nimport XSvg from \"./xSvg\";\nimport ReloadIcon from \"./reloadIcon\";\nimport EditIcon from \"./icons/edit\";\nimport DeleteIcon from \"./icons/delete\";\nimport Switch from \"./components/switch\";\nimport TooltipWrap from \"./tooltipWrap\";\nimport V2C_SettingsTitle from \"./settingsTitle\";\nimport V2C_SettingsGroup from \"./settingsGroup\";\nconst React = BDV2.React;\nconst anchorClasses = BDV2.anchorClasses;\nexport default class V2C_PresenceSettings extends BDV2.reactComponent {\n  constructor(props) {\n    super(props);\n    console.log(props);\n  }\n\n  updatePreview(data) {\n    this.setState({\n      data\n    });\n  }\n\n  render() {\n    let contentModule = BDModules.get(e => e.contentColumn)[0];\n    return React.createElement(\"div\", {\n      className: contentModule.contentColumn + \" \" + contentModule.contentColumnDefault + \" content-column default\",\n      style: {\n        padding: \"60px 40px 0px\"\n      }\n    }, React.createElement(V2C_SettingsGroup, {\n      title: \"RichPresence Settings\",\n      settings: this.props.settings,\n      onChange: this.props.onChange\n    }), React.createElement(V2C_SettingsTitle, {\n      text: \"RichPresence\"\n    }), React.createElement(\"div\", null, RPCProps.map(e => {\n      return React.createElement(PresenceSettingRow, {\n        setting: e\n      });\n    })), React.createElement(\"div\", null, React.createElement(RpcPreview, {\n      settings: this\n    })));\n  }\n\n}\n\nclass PresenceSettingRow extends BDV2.reactComponent {\n  render() {\n    let setting = this.props.setting;\n    let rowModule = BDModules.get(e => e.removeKeybind)[0];\n    let marginModule = BDModules.get(e => e.marginBottom20)[0];\n    let marginModule2 = BDModules.get(e => e.defaultMarginh5)[0];\n    let colorModule = BDModules.get(e => e.colorStandard)[0];\n    let sizeModule = BDModules.get(e => e.size32)[0];\n    return React.createElement(\"div\", {\n      className: rowModule.row + \" \" + marginModule.marginBottom20\n    }, React.createElement(\"div\", {\n      className: \"item-rJ_Cmt da-item flexChild-faoVW3 da-flexChild\"\n    }, React.createElement(\"h5\", {\n      className: colorModule.colorStandard + \" \" + sizeModule.size14 + \" \" + marginModule2.h5 + \" \" + marginModule2.defaultMarginh5\n    }, setting.title), React.createElement(\"div\", {\n      className: \"inputWrapper-31_8H8 da-inputWrapper\"\n    }, React.createElement(\"input\", {\n      class: \"inputDefault-_djjkz input-cIJ7To size16-1__VVI\",\n      name: \"state\",\n      type: \"text\",\n      placeholder: \"\",\n      maxlength: \"999\",\n      value: setting.default\n    }))), React.createElement(\"div\", {\n      class: \"divider-3573oO da-divider dividerDefault-3rvLe- da-dividerDefault\"\n    }));\n  }\n\n}\n\nclass RpcPreview extends BDV2.reactComponent {\n  constructor(props = {}) {\n    super(props);\n    this.state = {\n      active: \"profile\"\n    };\n    this.tabs = [];\n  }\n\n  changeTab(tab) {\n    let ancientTab = this.state.active;\n    if (ancientTab === tab.props.id) return;\n    this.tabs.forEach(e => {\n      e.setActive(false);\n    });\n    this.setState({\n      active: tab.id\n    });\n  }\n\n  render() {\n    return React.createElement(\"div\", {\n      className: \"lc-tabWrapper\"\n    }, React.createElement(\"div\", {\n      className: \"lc-tabnav\",\n      style: {\n        flex: \"0 1 auto\"\n      }\n    }, React.createElement(Tab, {\n      onClick: this.changeTab.bind(this),\n      preview: this,\n      title: \"Full Profile\",\n      id: \"profile\"\n    }), React.createElement(Tab, {\n      onClick: this.changeTab.bind(this),\n      preview: this,\n      title: \"User Popout\",\n      id: \"popout\"\n    })), React.createElement(Profile, null));\n  }\n\n  isActive(tab) {\n    return this.state.active === tab;\n  }\n  /**\r\n   * \r\n   * @param {string} tmplate \r\n   * @param {any} data \r\n   */\n\n\n  renderTemplate(tmplate, data) {\n    Object.keys(data).forEach(k => {\n      tmplate.replace(new RegExp(\"{{\" + k + \"}}\", \"g\"), data[k]);\n    });\n    return tmplate;\n  }\n\n}\n\nclass Tab extends BDV2.reactComponent {\n  constructor(props) {\n    super(props);\n    this.state = {\n      active: props.preview.isActive(props.id)\n    };\n    props.preview.tabs.push(this);\n  }\n\n  setActive(isActive) {\n    this.setState({\n      active: !!isActive\n    });\n  }\n\n  render() {\n    let className = `lc-navItem`;\n\n    if (this.state.active) {\n      className += ` lc-navItemActive`;\n    } else {\n      className += ` lc-navItemInactive`;\n    }\n\n    return React.createElement(\"div\", {\n      className: className,\n      onClick: () => {\n        this.props.onClick(this);\n        this.setActive(true);\n      }\n    }, this.props.title);\n  }\n\n}\n\nclass Status extends BDV2.reactComponent {\n  render() {\n    let status = BDModules.get(e => e.default && e.default.getPresence)[0].default.getPresence().status;\n    if (status === \"invisible\") status = \"offline\";\n    let className = \"pointerEvents-2zdfdO da-pointerEvents\";\n    return React.createElement(\"rect\", {\n      width: \"16\",\n      height: \"16\",\n      x: \"60\",\n      y: \"60\",\n      fill: \"#ffffff\",\n      mask: `url(#svg-mask-status-${status})`,\n      className: className\n    });\n  }\n\n}\n\nclass Profile extends BDV2.ReactComponent {\n  render() {\n    let user = BDModules.get(e => e.default && e.default.getCurrentUser)[0].default.getCurrentUser();\n    let avatarURL = user.getAvatarURL(user.avatar.startsWith(\"a_\") ? \"gif\" : \"png\");\n    let [flexModule1, stylingModule1, rootModule1, avatarModule1, nameTagModule1] = [BDModules.get(e => e.flex && e._horizontal)[0], BDModules.get(e => e.vertical && e.alignStretch)[0], BDModules.get(e => e.topSectionStreaming)[0], BDModules.get(e => e.pointerEvents)[0], BDModules.get(e => e.bot)[0]];\n    return [React.createElement(\"div\", {\n      className: \"lc-tab\"\n    }, React.createElement(\"div\", {\n      class: `${flexModule1.flex} ${stylingModule1.vertical} ${stylingModule1.justifyStart} ${stylingModule1.alignStretch} ${stylingModule1.noWrap} ${rootModule1.root}`,\n      style: {\n        flex: \"1 1 auto\"\n      }\n    }, React.createElement(\"div\", {\n      class: rootModule1.topSectionPlaying\n    }, React.createElement(\"header\", {\n      class: rootModule1.header\n    }, React.createElement(\"div\", {\n      class: `${rootModule1.avatar} ${avatarModule1.wrapper}`,\n      role: \"img\",\n      \"aria-hidden\": \"true\",\n      style: {\n        width: \"80px\",\n        height: \"80px\"\n      }\n    }, React.createElement(\"svg\", {\n      width: \"92\",\n      height: \"80\",\n      viewBox: \"0 0 92 80\",\n      class: \"mask-1l8v16 da-mask svg-2V3M55 da-svg\",\n      \"aria-hidden\": \"true\"\n    }, React.createElement(\"foreignObject\", {\n      x: \"0\",\n      y: \"0\",\n      width: \"80\",\n      height: \"80\",\n      mask: \"url(#svg-mask-avatar-status-round-80)\"\n    }, React.createElement(\"img\", {\n      src: avatarURL,\n      alt: \" \",\n      class: avatarModule1.avatar,\n      \"aria-hidden\": \"true\"\n    })), React.createElement(Status, null))), React.createElement(\"div\", {\n      class: `${rootModule1.headerInfo}`\n    }, React.createElement(\"div\", {\n      class: `${rootModule1.nameTag} ${nameTagModule1.nameTag}`\n    }, React.createElement(\"span\", {\n      class: `${rootModule1.username} ${rootModule1.username}`\n    }, user.username), React.createElement(\"span\", {\n      class: rootModule1.discriminator\n    }, \"#\", user.discriminator)), React.createElement(\"div\", {\n      class: `${flexModule1.flex} ${flexModule1.horizontal} ${stylingModule1.justifyStart} ${stylingModule1.alignStretch} ${stylingModule1.noWrap} ${rootModule1.profileBadges}`,\n      style: {\n        flex: \"1 1 auto\"\n      }\n    }, React.createElement(Badges, null)))), React.createElement(\"div\", {\n      class: rootModule1.headerFill\n    }, React.createElement(\"div\", {\n      class: \"activityProfile-2bJRaP da-activityProfile activity-1ythUs da-activity\"\n    }, React.createElement(\"h3\", {\n      class: \"headerTextNormal-2mGWX3 headerText-1HLrL7 marginBottom8-AtZOdT da-headerTextNormal da-headerText da-marginBottom8 base-1x0h_U da-base size12-3cLvbJ\"\n    }, \"En train de jouer\"), React.createElement(\"div\", {\n      class: \"bodyNormal-2D39hT body-ZAhrcj flex-1O1GKY alignStart-H-X2h- da-bodyNormal da-body da-flex da-alignStart\"\n    }, React.createElement(\"div\", {\n      class: \"assets-VMAukC da-assets\"\n    }, React.createElement(\"img\", {\n      alt: \"\",\n      src: \"https://cdn.discordapp.com/app-assets/708687209372581888/711293441526726747.png\",\n      class: \"assetsLargeImageProfile-3YXDex assetsLargeImage-eYwpTX noUserDrag-5Mb43F da-assetsLargeImageProfile da-assetsLargeImage da-noUserDrag assetsLargeMaskProfile-1Qkfen da-assetsLargeMaskProfile\"\n    }), React.createElement(\"img\", {\n      alt: \"\",\n      src: \"https://cdn.discordapp.com/app-assets/708687209372581888/711293441526726747.png\",\n      class: \"assetsSmallImageProfile-3JcsV1 assetsSmallImage-3_3Bzj noUserDrag-5Mb43F da-assetsSmallImageProfile da-assetsSmallImage da-noUserDrag\"\n    })), React.createElement(\"div\", {\n      class: \"contentImagesProfile-1Mz07W content-3JfFJh da-contentImagesProfile da-content\",\n      style: {\n        flex: \"1 1 auto\"\n      }\n    }, React.createElement(\"h3\", {\n      class: \"nameNormal-2lqVQK ellipsis-1XUmPN textRow-19NEd_ da-nameNormal da-ellipsis da-textRow base-1x0h_U da-base size14-e6ZScH\",\n      title: \"Deroku Vanity\"\n    }, React.createElement(\"span\", {\n      class: \"activityName-1IaRLn da-activityName\"\n    }, \"Deroku Vanity\")), React.createElement(\"div\", {\n      title: \"Lightcord test\",\n      class: \"details-38sfDr ellipsis-1XUmPN textRow-19NEd_ da-details da-ellipsis da-textRow\"\n    }, \"Lightcord test\"), React.createElement(\"div\", {\n      class: \"state-Tt0LO3 ellipsis-1XUmPN textRow-19NEd_ da-state da-ellipsis da-textRow\"\n    }, React.createElement(\"span\", {\n      title: \"gay comme phorcys\"\n    }, \"gay comme phorcys\")), React.createElement(\"div\", {\n      class: \"timestamp-VjAZmo ellipsis-1XUmPN textRow-19NEd_ da-timestamp da-ellipsis da-textRow\"\n    }, \"50\\xA0min\\xA024\\xA0s \\xE9coul\\xE9es\")))))), React.createElement(\"div\", {\n      class: rootModule1.body\n    }, React.createElement(\"div\", {\n      class: \"scrollerWrap-2lJEkd da-scrollerWrap scrollerFade-1Ijw5y da-scrollerFade\"\n    }, React.createElement(\"div\", {\n      class: \"scroller-2FKFPG da-scroller\"\n    }, React.createElement(\"div\", {\n      class: \"userInfoSection-2acyCx da-userInfoSection\"\n    }, React.createElement(\"div\", {\n      class: \"userInfoSectionHeader-CBvMDh da-userInfoSectionHeader\"\n    }, \"Note\"), React.createElement(\"div\", {\n      class: \"note-3kmerW da-note note-QfFU8y da-note\"\n    }, React.createElement(\"textarea\", {\n      placeholder: \"Clique pour ajouter une note\",\n      maxlength: \"256\",\n      autocorrect: \"off\",\n      class: \"scrollbarGhostHairline-1mSOM1 scrollbar-3dvm_9 da-scrollbarGhostHairline da-scrollbar\",\n      style: {\n        height: \"40px\"\n      },\n      disabled: true\n    }))), React.createElement(\"div\", {\n      class: \"userInfoSection-2acyCx da-userInfoSection\"\n    }, React.createElement(\"div\", {\n      class: \"connectedAccounts-repVzS da-connectedAccounts\"\n    }, React.createElement(\"div\", {\n      class: \"flex-1xMQg5 flex-1O1GKY da-flex da-flex horizontal-1ae9ci horizontal-2EEEnY flex-1O1GKY directionRow-3v3tfG justifyStart-2NDFzi alignCenter-1dQNNs noWrap-3jynv6 connectedAccount-36nQx7 da-connectedAccount\",\n      style: {\n        flex: \"0 1 auto\"\n      }\n    }, React.createElement(\"img\", {\n      alt: \"Logo Twitter\",\n      class: \"connectedAccountIcon-3P3V6F da-connectedAccountIcon\",\n      src: \"/assets/4662875160dc4c56954003ebda995414.png\"\n    }), React.createElement(\"div\", {\n      class: \"connectedAccountNameInner-1phBvE da-connectedAccountNameInner\"\n    }, React.createElement(\"div\", {\n      class: \"connectedAccountName-f8AEe2 da-connectedAccountName\"\n    }, \"jen_wina\"), React.createElement(\"span\", null, React.createElement(\"div\", {\n      class: \"flowerStarContainer-3zDVtj da-flowerStarContainer connectedAccountVerifiedIcon-3aZz_K da-connectedAccountVerifiedIcon\",\n      style: {\n        width: \"16px\",\n        height: \"16px\"\n      }\n    }, React.createElement(\"svg\", {\n      class: \"flowerStar-1GeTsn da-flowerStar\",\n      \"aria-hidden\": \"true\",\n      width: \"16\",\n      height: \"16\",\n      viewBox: \"0 0 16 15.2\"\n    }, React.createElement(\"path\", {\n      fill: \"#4f545c\",\n      \"fill-rule\": \"evenodd\",\n      d: \"m16 7.6c0 .79-1.28 1.38-1.52 2.09s.44 2 0 2.59-1.84.35-2.46.8-.79 1.84-1.54 2.09-1.67-.8-2.47-.8-1.75 1-2.47.8-.92-1.64-1.54-2.09-2-.18-2.46-.8.23-1.84 0-2.59-1.54-1.3-1.54-2.09 1.28-1.38 1.52-2.09-.44-2 0-2.59 1.85-.35 2.48-.8.78-1.84 1.53-2.12 1.67.83 2.47.83 1.75-1 2.47-.8.91 1.64 1.53 2.09 2 .18 2.46.8-.23 1.84 0 2.59 1.54 1.3 1.54 2.09z\"\n    })), React.createElement(\"div\", {\n      class: \"childContainer-1wxZNh da-childContainer\"\n    }, React.createElement(\"svg\", {\n      \"aria-hidden\": \"true\",\n      width: \"16\",\n      height: \"16\",\n      viewBox: \"0 0 16 15.2\"\n    }, React.createElement(\"path\", {\n      d: \"M7.4,11.17,4,8.62,5,7.26l2,1.53L10.64,4l1.36,1Z\",\n      fill: \"#ffffff\"\n    })))))), React.createElement(\"a\", {\n      class: \"anchor-3Z-8Bb da-anchor anchorUnderlineOnHover-2ESHQB da-anchorUnderlineOnHover\",\n      rel: \"noreferrer noopener\",\n      target: \"_blank\",\n      role: \"button\",\n      tabindex: \"0\"\n    }, React.createElement(\"svg\", {\n      class: \"connectedAccountOpenIcon-2cNbq5 da-connectedAccountOpenIcon\",\n      \"aria-hidden\": \"true\",\n      width: \"24\",\n      height: \"24\",\n      viewBox: \"0 0 24 24\"\n    }, React.createElement(\"path\", {\n      fill: \"currentColor\",\n      d: \"M10 5V3H5.375C4.06519 3 3 4.06519 3 5.375V18.625C3 19.936 4.06519 21 5.375 21H18.625C19.936 21 21 19.936 21 18.625V14H19V19H5V5H10Z\"\n    }), React.createElement(\"path\", {\n      fill: \"currentColor\",\n      d: \"M21 2.99902H14V4.99902H17.586L9.29297 13.292L10.707 14.706L19 6.41302V9.99902H21V2.99902Z\"\n    }))))))))))), React.createElement(\"div\", {\n      class: \"lc-fadeOverlay\"\n    })];\n  }\n\n}\n\nclass Badges extends BDV2.reactComponent {\n  render() {\n    let user = BDModules.get(e => e.default && e.default.getCurrentUser)[0].default.getCurrentUser();\n    let rootModule = BDModules.get(e => e.topSectionStreaming)[0];\n    let UserFlags = BDModules.get(e => e.UserFlags)[0].UserFlags;\n    let badges = [];\n    let serialized = [];\n\n    for (let flagName in UserFlags) {\n      if (user.hasFlag(UserFlags[flagName])) serialized.push(flagName);\n    }\n\n    for (let flagName of serialized) {\n      let searchable = `profileBadge${flagName.toLowerCase().replace(/_/g, \" \").split(\" \").map(e => e[0].toUpperCase() + e.slice(1)).join(\"\")}`;\n      searchable = searchable.replace(\"HypesquadOnline\", \"HypeSquadOnline\");\n      console.log(searchable, rootModule[searchable]);\n      if (!rootModule[searchable]) continue;\n      badges.push(React.createElement(Badge, {\n        name: searchable\n      }));\n    }\n\n    if (user.hasPremiumSubscription) {\n      badges.push(React.createElement(Badge, {\n        name: \"profileBadgePremium\"\n      }));\n    }\n\n    return badges;\n  }\n\n}\n\nclass Badge extends BDV2.reactComponent {\n  render() {\n    let rootModule1 = BDModules.get(e => e.topSectionStreaming)[0];\n    return React.createElement(\"div\", {\n      class: rootModule1.profileBadgeWrapper\n    }, React.createElement(\"div\", null, React.createElement(\"div\", {\n      class: \"\",\n      role: \"button\",\n      tabindex: \"0\"\n    }, React.createElement(\"div\", {\n      class: `profileBadge-2BqF-Z da-profileBadge ${rootModule1[this.props.name]}`\n    }))));\n  }\n\n}\n\nconst RPCProps = [{\n  title: \"State\",\n  id: \"state\",\n  default: \"Browsing Discord\",\n  type: \"text\"\n}, {\n  title: \"Details\",\n  id: \"details\",\n  default: \"Lightcord\",\n  type: \"text\"\n}];\nconst Constants = {\n  PresenceViewer: {\n    USER_ACTIVITY_HEADER_WATCHING: \"Watching {name}\",\n    USER_ACTIVITY_HEADER_PLAYING: \"Playing a game\",\n    USER_ACTIVITY_STATE_SIZE: \"({count} of {max})\",\n    USER_ACTIVITY_TIMESTAMP_END: \"{hours, plural, =-1 {} other {{hours}:}}{minutes, plural, =-1 {} other {{minutes}:}}{seconds, plural, =-1 {} other {{seconds}}} left\",\n    USER_ACTIVITY_TIMESTAMP_START: \"{hours, plural, =-1 {} other {{hours}:}}{minutes, plural, =-1 {} other {{minutes}:}}{seconds, plural, =-1 {} other {{seconds}}} elapsed\",\n    USER_ACTIVITY_ACTION_NOTIFY_ME: \"Notify Me\",\n    USER_ACTIVITY_ACTION_ASK_TO_JOIN: \"Ask to Join\",\n    USER_ACTIVITY_ACTION_SPECTATE: \"Spectate\",\n    SECTION_TITLE: \"Rich Presence Visualizer\",\n    SECTION_MORE_INFO: \"Rich Presence lets your game surface exciting game data on your players' profiles, and lets them play together with chat invites, Ask to Join, and Spectate. See exactly how your text and art will look on a user's profile.\",\n    PROFILE: \"Full Profile\",\n    USER_POPOUT: \"User Popout\",\n    ACTIVITY_FEED: \"Games Tab\",\n    NONE: \"None\",\n    SHOW_CODE: \"Show Code\",\n    MOBILE_ALERT: \"Rich Presence Visualizer only available on desktop\",\n    PARTY_ID_MUST_BE_UNIQUE: \"Party ID can't match Join or Spectate Secrets.\",\n    SECRETS_MUST_BE_UNIQUE: \"Join and Spectate Secrets must be unique strings.\"\n  },\n  Tooltips: {\n    STATE: \"[type: char*]\\nThe user's current party status\",\n    DETAILS: \"[type: char*]\\nWhat the player is currently doing\",\n    START_TIMESTAMP: '[type: int64_t]\\nEpoch seconds for game start - including will show time as \"elapsed\"',\n    END_TIMESTAMP: '[type: int64_t]\\nEpoch seconds for game end - including will show time as \"remaining\"\\t',\n    LARGE_IMAGE_KEY: \"[type: char*]\\nKey of the uploaded image for the large profile artwork\",\n    LARGE_IMAGE_TEXT: \"[type: char*]\\nTooltip for the largeImageKey\",\n    SMALL_IMAGE_KEY: \"[type: char*]\\nKey of the uploaded image for the small profile artwork\",\n    SMALL_IMAGE_TEXT: \"[type: char*]\\nTooltip for the smallImageKey\",\n    PARTY_ID: \"[type: char*]\\nId of the player's party, lobby, or group\",\n    PARTY_SIZE: \"[type: int]\\nCurrent size of the player's party, lobby, or group\",\n    PARTY_MAX: \"[type: int]\\nMaximum size of the player's party, lobby, or group\\t\",\n    SPECTATE_SECRET: \"[type: char*]\\nUnique hashed string for Spectate button\",\n    JOIN_SECRET: \"[type: char*]\\nUnique hashed string for chat invitations and Ask to Join\"\n  },\n  UserProfile: {\n    USER_INFO: \"User Info\",\n    MUTUAL_SERVERS: \"Mutual Servers\",\n    MUTUAL_FRIENDS: \"Mutual Friends\",\n    NOTE: \"Note\",\n    ADD_NOTE: \"Click to add note\"\n  }\n};"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/ui/presenceSettings.jsx\n"); + +/***/ }), + +/***/ "./src/ui/publicservers/layer.js": +/*!***************************************!*\ + !*** ./src/ui/publicservers/layer.js ***! + \***************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_Layer; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _modules_domtools__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../modules/domtools */ \"./src/modules/domtools.js\");\n\n\nclass V2C_Layer extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n this.keyupListener = this.keyupListener.bind(this);\n }\n\n keyupListener(e) {\n if (e.which === 27) {\n _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactDom.unmountComponentAtNode(this.refs.root.parentNode);\n }\n }\n\n componentDidMount() {\n window.addEventListener(\"keyup\", this.keyupListener);\n const thisNode = _modules_domtools__WEBPACK_IMPORTED_MODULE_1__[\"default\"].query(`#${this.props.id}`);\n _modules_domtools__WEBPACK_IMPORTED_MODULE_1__[\"default\"].animate({\n duration: 200,\n update: function (progress) {\n thisNode.style.transform = `scale(${1.1 - 0.1 * progress}) translateZ(0px)`;\n thisNode.style.opacity = progress;\n\n if (progress == 1) {\n setImmediate(() => {\n thisNode.style.transform = \"\";\n thisNode.style.opacity = \"\";\n });\n }\n }\n });\n }\n\n componentWillUnmount() {\n window.removeEventListener(\"keyup\", this.keyupListener);\n const thisNode = _modules_domtools__WEBPACK_IMPORTED_MODULE_1__[\"default\"].query(`#${this.props.id}`);\n _modules_domtools__WEBPACK_IMPORTED_MODULE_1__[\"default\"].animate({\n duration: 200,\n update: function (progress) {\n thisNode.style.transform = `scale(${1.1 - 0.1 * (1 - progress)}) translateZ(0px)`;\n thisNode.style.opacity = 1 - progress;\n\n if (progress == 1) {\n setImmediate(() => {\n thisNode.remove();\n });\n }\n }\n });\n const layer = _modules_domtools__WEBPACK_IMPORTED_MODULE_1__[\"default\"].query(\".publicServersOpen\");\n layer.classList.remove(\"publicServersOpen\");\n _modules_domtools__WEBPACK_IMPORTED_MODULE_1__[\"default\"].animate({\n duration: 200,\n update: function (progress) {\n layer.style.transform = `scale(${0.07 * progress + 0.93}) translateZ(0px)`;\n layer.style.opacity = progress;\n\n if (progress == 1) {\n setImmediate(() => {\n layer.style.transform = \"\";\n layer.style.opacity = \"\";\n });\n }\n }\n });\n }\n\n componentWillMount() {\n const layer = _modules_domtools__WEBPACK_IMPORTED_MODULE_1__[\"default\"].query(\"[class*=\\\"layer-\\\"]\");\n layer.classList.add(\"publicServersOpen\");\n _modules_domtools__WEBPACK_IMPORTED_MODULE_1__[\"default\"].animate({\n duration: 200,\n update: function (progress) {\n layer.style.transform = `scale(${0.07 * (1 - progress) + 0.93}) translateZ(0px)`;\n layer.style.opacity = 1 - progress;\n }\n });\n }\n\n render() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"layer bd-layer \" + BDModules.get(e => e.layer && e.animating)[0].layer,\n id: this.props.id,\n ref: \"root\",\n style: {\n opacity: 0,\n transform: \"scale(1.1) translateZ(0px)\"\n }\n }, this.props.children);\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvcHVibGljc2VydmVycy9sYXllci5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvcHVibGljc2VydmVycy9sYXllci5qcz9lNDFkIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi8uLi9tb2R1bGVzL3YyXCI7XG5pbXBvcnQgRE9NIGZyb20gXCIuLi8uLi9tb2R1bGVzL2RvbXRvb2xzXCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWMkNfTGF5ZXIgZXh0ZW5kcyBCRFYyLnJlYWN0Q29tcG9uZW50IHtcbiAgY29uc3RydWN0b3IocHJvcHMpIHtcbiAgICBzdXBlcihwcm9wcyk7XG4gICAgdGhpcy5rZXl1cExpc3RlbmVyID0gdGhpcy5rZXl1cExpc3RlbmVyLmJpbmQodGhpcyk7XG4gIH1cblxuICBrZXl1cExpc3RlbmVyKGUpIHtcbiAgICBpZiAoZS53aGljaCA9PT0gMjcpIHtcbiAgICAgIEJEVjIucmVhY3REb20udW5tb3VudENvbXBvbmVudEF0Tm9kZSh0aGlzLnJlZnMucm9vdC5wYXJlbnROb2RlKTtcbiAgICB9XG4gIH1cblxuICBjb21wb25lbnREaWRNb3VudCgpIHtcbiAgICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcihcImtleXVwXCIsIHRoaXMua2V5dXBMaXN0ZW5lcik7XG4gICAgY29uc3QgdGhpc05vZGUgPSBET00ucXVlcnkoYCMke3RoaXMucHJvcHMuaWR9YCk7XG4gICAgRE9NLmFuaW1hdGUoe1xuICAgICAgZHVyYXRpb246IDIwMCxcbiAgICAgIHVwZGF0ZTogZnVuY3Rpb24gKHByb2dyZXNzKSB7XG4gICAgICAgIHRoaXNOb2RlLnN0eWxlLnRyYW5zZm9ybSA9IGBzY2FsZSgkezEuMSAtIDAuMSAqIHByb2dyZXNzfSkgdHJhbnNsYXRlWigwcHgpYDtcbiAgICAgICAgdGhpc05vZGUuc3R5bGUub3BhY2l0eSA9IHByb2dyZXNzO1xuXG4gICAgICAgIGlmIChwcm9ncmVzcyA9PSAxKSB7XG4gICAgICAgICAgc2V0SW1tZWRpYXRlKCgpID0+IHtcbiAgICAgICAgICAgIHRoaXNOb2RlLnN0eWxlLnRyYW5zZm9ybSA9IFwiXCI7XG4gICAgICAgICAgICB0aGlzTm9kZS5zdHlsZS5vcGFjaXR5ID0gXCJcIjtcbiAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgY29tcG9uZW50V2lsbFVubW91bnQoKSB7XG4gICAgd2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoXCJrZXl1cFwiLCB0aGlzLmtleXVwTGlzdGVuZXIpO1xuICAgIGNvbnN0IHRoaXNOb2RlID0gRE9NLnF1ZXJ5KGAjJHt0aGlzLnByb3BzLmlkfWApO1xuICAgIERPTS5hbmltYXRlKHtcbiAgICAgIGR1cmF0aW9uOiAyMDAsXG4gICAgICB1cGRhdGU6IGZ1bmN0aW9uIChwcm9ncmVzcykge1xuICAgICAgICB0aGlzTm9kZS5zdHlsZS50cmFuc2Zvcm0gPSBgc2NhbGUoJHsxLjEgLSAwLjEgKiAoMSAtIHByb2dyZXNzKX0pIHRyYW5zbGF0ZVooMHB4KWA7XG4gICAgICAgIHRoaXNOb2RlLnN0eWxlLm9wYWNpdHkgPSAxIC0gcHJvZ3Jlc3M7XG5cbiAgICAgICAgaWYgKHByb2dyZXNzID09IDEpIHtcbiAgICAgICAgICBzZXRJbW1lZGlhdGUoKCkgPT4ge1xuICAgICAgICAgICAgdGhpc05vZGUucmVtb3ZlKCk7XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KTtcbiAgICBjb25zdCBsYXllciA9IERPTS5xdWVyeShcIi5wdWJsaWNTZXJ2ZXJzT3BlblwiKTtcbiAgICBsYXllci5jbGFzc0xpc3QucmVtb3ZlKFwicHVibGljU2VydmVyc09wZW5cIik7XG4gICAgRE9NLmFuaW1hdGUoe1xuICAgICAgZHVyYXRpb246IDIwMCxcbiAgICAgIHVwZGF0ZTogZnVuY3Rpb24gKHByb2dyZXNzKSB7XG4gICAgICAgIGxheWVyLnN0eWxlLnRyYW5zZm9ybSA9IGBzY2FsZSgkezAuMDcgKiBwcm9ncmVzcyArIDAuOTN9KSB0cmFuc2xhdGVaKDBweClgO1xuICAgICAgICBsYXllci5zdHlsZS5vcGFjaXR5ID0gcHJvZ3Jlc3M7XG5cbiAgICAgICAgaWYgKHByb2dyZXNzID09IDEpIHtcbiAgICAgICAgICBzZXRJbW1lZGlhdGUoKCkgPT4ge1xuICAgICAgICAgICAgbGF5ZXIuc3R5bGUudHJhbnNmb3JtID0gXCJcIjtcbiAgICAgICAgICAgIGxheWVyLnN0eWxlLm9wYWNpdHkgPSBcIlwiO1xuICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICBjb21wb25lbnRXaWxsTW91bnQoKSB7XG4gICAgY29uc3QgbGF5ZXIgPSBET00ucXVlcnkoXCJbY2xhc3MqPVxcXCJsYXllci1cXFwiXVwiKTtcbiAgICBsYXllci5jbGFzc0xpc3QuYWRkKFwicHVibGljU2VydmVyc09wZW5cIik7XG4gICAgRE9NLmFuaW1hdGUoe1xuICAgICAgZHVyYXRpb246IDIwMCxcbiAgICAgIHVwZGF0ZTogZnVuY3Rpb24gKHByb2dyZXNzKSB7XG4gICAgICAgIGxheWVyLnN0eWxlLnRyYW5zZm9ybSA9IGBzY2FsZSgkezAuMDcgKiAoMSAtIHByb2dyZXNzKSArIDAuOTN9KSB0cmFuc2xhdGVaKDBweClgO1xuICAgICAgICBsYXllci5zdHlsZS5vcGFjaXR5ID0gMSAtIHByb2dyZXNzO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIHJldHVybiBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcImxheWVyIGJkLWxheWVyIFwiICsgQkRNb2R1bGVzLmdldChlID0+IGUubGF5ZXIgJiYgZS5hbmltYXRpbmcpWzBdLmxheWVyLFxuICAgICAgaWQ6IHRoaXMucHJvcHMuaWQsXG4gICAgICByZWY6IFwicm9vdFwiLFxuICAgICAgc3R5bGU6IHtcbiAgICAgICAgb3BhY2l0eTogMCxcbiAgICAgICAgdHJhbnNmb3JtOiBcInNjYWxlKDEuMSkgdHJhbnNsYXRlWigwcHgpXCJcbiAgICAgIH1cbiAgICB9LCB0aGlzLnByb3BzLmNoaWxkcmVuKTtcbiAgfVxuXG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/publicservers/layer.js\n"); + +/***/ }), + +/***/ "./src/ui/publicservers/publicServers.js": +/*!***********************************************!*\ + !*** ./src/ui/publicservers/publicServers.js ***! + \***********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_PublicServers; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _tools__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../tools */ \"./src/ui/tools.js\");\n/* harmony import */ var _settingsTitle__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../settingsTitle */ \"./src/ui/settingsTitle.js\");\n/* harmony import */ var _tabBarSeparator__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../tabBarSeparator */ \"./src/ui/tabBarSeparator.js\");\n/* harmony import */ var _tabBarHeader__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../tabBarHeader */ \"./src/ui/tabBarHeader.js\");\n/* harmony import */ var _tabBarItem__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../tabBarItem */ \"./src/ui/tabBarItem.js\");\n/* harmony import */ var _serverCard__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./serverCard */ \"./src/ui/publicservers/serverCard.js\");\n/* harmony import */ var _sidebarView__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./sidebarView */ \"./src/ui/publicservers/sidebarView.js\");\n\n\n\n\n\n\n\n\nclass V2C_PublicServers extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n this.setInitialState();\n this.close = this.close.bind(this);\n this.changeCategory = this.changeCategory.bind(this);\n this.search = this.search.bind(this);\n this.searchKeyDown = this.searchKeyDown.bind(this);\n this.checkConnection = this.checkConnection.bind(this);\n this.join = this.join.bind(this);\n this.connect = this.connect.bind(this);\n this.GuildStore = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].WebpackModules.findByUniqueProperties([\"getGuilds\"]);\n this.AvatarDefaults = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].WebpackModules.findByUniqueProperties([\"getUserAvatarURL\", \"DEFAULT_AVATARS\"]);\n this.InviteActions = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].WebpackModules.findByUniqueProperties([\"acceptInvite\"]);\n this.SortedGuildStore = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].WebpackModules.findByUniqueProperties([\"getSortedGuilds\"]);\n }\n\n componentDidMount() {\n this.checkConnection();\n }\n\n setInitialState() {\n this.state = {\n selectedCategory: -1,\n title: \"Loading...\",\n loading: true,\n servers: [],\n next: null,\n connection: {\n state: 0,\n user: null\n }\n };\n }\n\n close() {\n _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactDom.unmountComponentAtNode(document.getElementById(this.props.rootId));\n }\n\n search(query, clear) {\n const self = this;\n fetch(`${self.endPoint}${query}${query ? \"&schema=new\" : \"?schema=new\"}`, {\n method: \"get\"\n }).then(async res => {\n if (res.status !== 200) throw await res.text();\n let data = await res.json();\n let servers = data.results.reduce((arr, server) => {\n server.joined = false;\n arr.push(server); // arr.push();\n\n return arr;\n }, []);\n\n if (!clear) {\n servers = self.state.servers.concat(servers);\n } else {//servers.unshift(self.bdServer);\n }\n\n let end = data.size + data.from;\n data.next = `?from=${end}`;\n if (self.state.term) data.next += `&term=${self.state.term}`;\n if (self.state.selectedCategory) data.next += `&category=${self.categoryButtons[self.state.selectedCategory]}`;\n\n if (end >= data.total) {\n end = data.total;\n data.next = null;\n }\n\n let title = `Showing 1-${end} of ${data.total} results in ${self.categoryButtons[self.state.selectedCategory]}`;\n if (self.state.term) title += ` for ${self.state.term}`;\n self.setState({\n loading: false,\n title: title,\n servers: servers,\n next: data.next\n });\n\n if (clear) {\n //console.log(self);\n self.refs.sbv.refs.contentScroller.scrollTop = 0;\n }\n }).catch(err => {\n console.error(err);\n return self.setState({\n loading: false,\n title: \"Failed to load servers. Check console for details\"\n });\n });\n }\n\n async join(serverCard) {\n if (serverCard.props.pinned) return this.InviteActions.acceptInvite(serverCard.props.invite_code);\n await fetch(`${this.joinEndPoint}/${serverCard.props.server.identifier}`, {\n method: \"GET\",\n credentials: \"include\",\n mode: \"cors\",\n headers: {\n \"Accept\": \"application/json\",\n \"Content-Type\": \"application/json\"\n }\n });\n serverCard.setState({\n joined: true\n });\n }\n\n connect() {\n const self = this;\n const options = self.windowOptions;\n options.x = Math.round(window.screenX + window.innerWidth / 2 - options.width / 2);\n options.y = Math.round(window.screenY + window.innerHeight / 2 - options.height / 2);\n self.joinWindow = new (window.require(\"electron\").remote.BrowserWindow)(options);\n const url = \"https://auth.discordservers.com/connect?scopes=guilds.join&previousUrl=https://auth.discordservers.com/info\";\n self.joinWindow.webContents.on(\"did-navigate\", (event, url) => {\n if (url != \"https://auth.discordservers.com/info\") return;\n self.joinWindow.close();\n self.checkConnection();\n });\n self.joinWindow.loadURL(url);\n }\n\n get windowOptions() {\n return {\n width: 500,\n height: 550,\n backgroundColor: \"#282b30\",\n show: true,\n resizable: false,\n maximizable: false,\n minimizable: false,\n alwaysOnTop: true,\n frame: false,\n center: false,\n webPreferences: {\n nodeIntegration: false\n }\n };\n }\n\n get bdServer() {\n const server = {\n name: \"BetterDiscord\",\n online: \"7500+\",\n members: \"20000+\",\n categories: [\"community\", \"programming\", \"support\"],\n description: \"Official BetterDiscord server for support etc\",\n identifier: \"86004744966914048\",\n iconUrl: \"https://cdn.discordapp.com/icons/86004744966914048/292e7f6bfff2b71dfd13e508a859aedd.webp\",\n nativejoin: true,\n invite_code: \"0Tmfo5ZbORCRqbAd\",\n pinned: true\n };\n const guildList = this.SortedGuildStore.getFlattenedGuildIds();\n const defaultList = this.AvatarDefaults.DEFAULT_AVATARS;\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_serverCard__WEBPACK_IMPORTED_MODULE_6__[\"default\"], {\n server: server,\n pinned: true,\n join: this.join,\n guildList: guildList,\n fallback: defaultList[Math.floor(Math.random() * 5)]\n });\n }\n\n get endPoint() {\n return \"https://search.discordservers.com\";\n }\n\n get joinEndPoint() {\n return \"https://j.discordservers.com\";\n }\n\n get connectEndPoint() {\n return \"https://join.discordservers.com/connect\";\n }\n\n async checkConnection() {\n const self = this;\n\n try {\n const response = await fetch(`https://auth.discordservers.com/info`, {\n method: \"GET\",\n credentials: \"include\",\n mode: \"cors\",\n headers: {\n \"Accept\": \"application/json\",\n \"Content-Type\": \"application/json\"\n }\n });\n const data = await response.json();\n self.setState({\n selectedCategory: 0,\n connection: {\n state: 2,\n user: data\n }\n });\n self.search(\"\", true);\n } catch (error) {\n console.error(error);\n self.setState({\n title: \"Not connected to discordservers.com!\",\n loading: true,\n selectedCategory: -1,\n connection: {\n state: 1,\n user: null\n }\n });\n }\n }\n\n render() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_sidebarView__WEBPACK_IMPORTED_MODULE_7__[\"default\"], {\n ref: \"sbv\"\n }, this.component);\n }\n\n get component() {\n return {\n sidebar: {\n component: this.sidebar\n },\n content: {\n component: this.content\n },\n tools: {\n component: _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_tools__WEBPACK_IMPORTED_MODULE_1__[\"default\"], {\n key: \"pt\",\n ref: \"tools\",\n onClick: this.close\n })\n }\n };\n }\n\n get sidebar() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"sidebar\",\n key: \"ps\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-tab-bar SIDE\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-tab-bar-header\",\n style: {\n fontSize: \"16px\"\n }\n }, \"Public Servers\"), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_tabBarSeparator__WEBPACK_IMPORTED_MODULE_3__[\"default\"], null), this.searchInput, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_tabBarSeparator__WEBPACK_IMPORTED_MODULE_3__[\"default\"], null), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_tabBarHeader__WEBPACK_IMPORTED_MODULE_4__[\"default\"], {\n text: \"Categories\"\n }), this.categoryButtons.map((value, index) => {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_tabBarItem__WEBPACK_IMPORTED_MODULE_5__[\"default\"], {\n id: index,\n onClick: this.changeCategory,\n key: index,\n text: value,\n selected: this.state.selectedCategory === index\n });\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_tabBarSeparator__WEBPACK_IMPORTED_MODULE_3__[\"default\"], null), this.footer, this.connection));\n }\n\n get searchInput() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-form-item\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-text-input flex-vertical\",\n style: {\n width: \"172px\",\n marginLeft: \"10px\"\n }\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"input\", {\n ref: \"searchinput\",\n onKeyDown: this.searchKeyDown,\n onChange: () => {},\n type: \"text\",\n className: \"input default\",\n placeholder: \"Search...\",\n maxLength: \"50\"\n })));\n }\n\n searchKeyDown(e) {\n const self = this;\n if (self.state.loading || e.which !== 13) return;\n self.setState({\n loading: true,\n title: \"Loading...\",\n term: e.target.value\n });\n let query = `?term=${e.target.value}`;\n\n if (self.state.selectedCategory !== 0) {\n query += `&category=${self.categoryButtons[self.state.selectedCategory]}`;\n }\n\n self.search(query, true);\n }\n\n get categoryButtons() {\n return [\"All\", \"FPS Games\", \"MMO Games\", \"Strategy Games\", \"MOBA Games\", \"RPG Games\", \"Tabletop Games\", \"Sandbox Games\", \"Simulation Games\", \"Music\", \"Community\", \"Language\", \"Programming\", \"Other\"];\n }\n\n changeCategory(id) {\n const self = this;\n if (self.state.loading) return;\n self.refs.searchinput.value = \"\";\n self.setState({\n loading: true,\n selectedCategory: id,\n title: \"Loading...\",\n term: null\n });\n\n if (id === 0) {\n self.search(\"\", true);\n return;\n }\n\n self.search(`?category=${self.categoryButtons[id]}`, true);\n }\n\n get content() {\n const self = this;\n const guildList = this.SortedGuildStore.getFlattenedGuildIds();\n const defaultList = this.AvatarDefaults.DEFAULT_AVATARS;\n if (self.state.connection.state === 1) return self.notConnected;\n let columnModule = BDModules.get(e => e.contentColumnDefault)[0];\n return [_modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n ref: \"content\",\n key: \"pc\",\n className: columnModule.contentColumn + \" \" + columnModule.contentColumn + \" content-column default\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_settingsTitle__WEBPACK_IMPORTED_MODULE_2__[\"default\"], {\n text: self.state.title\n }), self.bdServer, self.state.servers.map(server => {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_serverCard__WEBPACK_IMPORTED_MODULE_6__[\"default\"], {\n key: server.identifier,\n server: server,\n join: self.join,\n guildList: guildList,\n fallback: defaultList[Math.floor(Math.random() * 5)]\n });\n }), self.state.next && _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"button\", {\n type: \"button\",\n onClick: () => {\n if (self.state.loading) return;\n self.setState({\n loading: true\n });\n self.search(self.state.next, false);\n },\n className: \"ui-button filled brand small grow\",\n style: {\n width: \"100%\",\n marginTop: \"10px\",\n marginBottom: \"10px\"\n }\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-button-contents\"\n }, self.state.loading ? \"Loading\" : \"Load More\")), self.state.servers.length > 0 && _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_settingsTitle__WEBPACK_IMPORTED_MODULE_2__[\"default\"], {\n text: self.state.title\n }))];\n }\n\n get notConnected() {\n const self = this; //return BDV2.react.createElement(SettingsTitle, { text: self.state.title });\n\n let columnModule = BDModules.get(e => e.contentColumnDefault)[0];\n return [_modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n key: \"ncc\",\n ref: \"content\",\n className: columnModule.contentColumn + \" \" + columnModule.contentColumn + \" content-column default\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"h2\", {\n className: \"ui-form-title h2 margin-reset margin-bottom-20\"\n }, \"Not connected to discordservers.com!\", _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"button\", {\n onClick: self.connect,\n type: \"button\",\n className: \"ui-button filled brand small grow\",\n style: {\n display: \"inline-block\",\n minHeight: \"18px\",\n marginLeft: \"10px\",\n lineHeight: \"14px\"\n }\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-button-contents\"\n }, \"Connect\"))), self.bdServer)];\n }\n\n get footer() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-tab-bar-header\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"a\", {\n href: \"https://discordservers.com\",\n target: \"_blank\"\n }, \"Discordservers.com\"));\n }\n\n get connection() {\n const self = this;\n const {\n connection\n } = self.state;\n if (connection.state !== 2) return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"span\", null);\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"span\", null, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_tabBarSeparator__WEBPACK_IMPORTED_MODULE_3__[\"default\"], null), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"span\", {\n style: {\n color: \"#b9bbbe\",\n fontSize: \"10px\",\n marginLeft: \"10px\"\n }\n }, \"Connected as: \", `${connection.user.username}#${connection.user.discriminator}`), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n style: {\n padding: \"5px 10px 0 10px\"\n }\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"button\", {\n style: {\n width: \"100%\",\n minHeight: \"20px\"\n },\n type: \"button\",\n className: \"ui-button filled brand small grow\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-button-contents\",\n onClick: self.connect\n }, \"Reconnect\"))));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/ui/publicservers/publicServers.js.js","sources":["webpack://BetterDiscord/./src/ui/publicservers/publicServers.js?3bda"],"sourcesContent":["import BDV2 from \"../../modules/v2\";\nimport Tools from \"../tools\";\nimport SettingsTitle from \"../settingsTitle\";\nimport TabBarSeparator from \"../tabBarSeparator\";\nimport TabBarHeader from \"../tabBarHeader\";\nimport TabBarItem from \"../tabBarItem\";\nimport ServerCard from \"./serverCard\";\nimport SidebarView from \"./sidebarView\";\nexport default class V2C_PublicServers extends BDV2.reactComponent {\n  constructor(props) {\n    super(props);\n    this.setInitialState();\n    this.close = this.close.bind(this);\n    this.changeCategory = this.changeCategory.bind(this);\n    this.search = this.search.bind(this);\n    this.searchKeyDown = this.searchKeyDown.bind(this);\n    this.checkConnection = this.checkConnection.bind(this);\n    this.join = this.join.bind(this);\n    this.connect = this.connect.bind(this);\n    this.GuildStore = BDV2.WebpackModules.findByUniqueProperties([\"getGuilds\"]);\n    this.AvatarDefaults = BDV2.WebpackModules.findByUniqueProperties([\"getUserAvatarURL\", \"DEFAULT_AVATARS\"]);\n    this.InviteActions = BDV2.WebpackModules.findByUniqueProperties([\"acceptInvite\"]);\n    this.SortedGuildStore = BDV2.WebpackModules.findByUniqueProperties([\"getSortedGuilds\"]);\n  }\n\n  componentDidMount() {\n    this.checkConnection();\n  }\n\n  setInitialState() {\n    this.state = {\n      selectedCategory: -1,\n      title: \"Loading...\",\n      loading: true,\n      servers: [],\n      next: null,\n      connection: {\n        state: 0,\n        user: null\n      }\n    };\n  }\n\n  close() {\n    BDV2.reactDom.unmountComponentAtNode(document.getElementById(this.props.rootId));\n  }\n\n  search(query, clear) {\n    const self = this;\n    fetch(`${self.endPoint}${query}${query ? \"&schema=new\" : \"?schema=new\"}`, {\n      method: \"get\"\n    }).then(async res => {\n      if (res.status !== 200) throw await res.text();\n      let data = await res.json();\n      let servers = data.results.reduce((arr, server) => {\n        server.joined = false;\n        arr.push(server); // arr.push(<ServerCard server={server} join={self.join}/>);\n\n        return arr;\n      }, []);\n\n      if (!clear) {\n        servers = self.state.servers.concat(servers);\n      } else {//servers.unshift(self.bdServer);\n      }\n\n      let end = data.size + data.from;\n      data.next = `?from=${end}`;\n      if (self.state.term) data.next += `&term=${self.state.term}`;\n      if (self.state.selectedCategory) data.next += `&category=${self.categoryButtons[self.state.selectedCategory]}`;\n\n      if (end >= data.total) {\n        end = data.total;\n        data.next = null;\n      }\n\n      let title = `Showing 1-${end} of ${data.total} results in ${self.categoryButtons[self.state.selectedCategory]}`;\n      if (self.state.term) title += ` for ${self.state.term}`;\n      self.setState({\n        loading: false,\n        title: title,\n        servers: servers,\n        next: data.next\n      });\n\n      if (clear) {\n        //console.log(self);\n        self.refs.sbv.refs.contentScroller.scrollTop = 0;\n      }\n    }).catch(err => {\n      console.error(err);\n      return self.setState({\n        loading: false,\n        title: \"Failed to load servers. Check console for details\"\n      });\n    });\n  }\n\n  async join(serverCard) {\n    if (serverCard.props.pinned) return this.InviteActions.acceptInvite(serverCard.props.invite_code);\n    await fetch(`${this.joinEndPoint}/${serverCard.props.server.identifier}`, {\n      method: \"GET\",\n      credentials: \"include\",\n      mode: \"cors\",\n      headers: {\n        \"Accept\": \"application/json\",\n        \"Content-Type\": \"application/json\"\n      }\n    });\n    serverCard.setState({\n      joined: true\n    });\n  }\n\n  connect() {\n    const self = this;\n    const options = self.windowOptions;\n    options.x = Math.round(window.screenX + window.innerWidth / 2 - options.width / 2);\n    options.y = Math.round(window.screenY + window.innerHeight / 2 - options.height / 2);\n    self.joinWindow = new (window.require(\"electron\").remote.BrowserWindow)(options);\n    const url = \"https://auth.discordservers.com/connect?scopes=guilds.join&previousUrl=https://auth.discordservers.com/info\";\n    self.joinWindow.webContents.on(\"did-navigate\", (event, url) => {\n      if (url != \"https://auth.discordservers.com/info\") return;\n      self.joinWindow.close();\n      self.checkConnection();\n    });\n    self.joinWindow.loadURL(url);\n  }\n\n  get windowOptions() {\n    return {\n      width: 500,\n      height: 550,\n      backgroundColor: \"#282b30\",\n      show: true,\n      resizable: false,\n      maximizable: false,\n      minimizable: false,\n      alwaysOnTop: true,\n      frame: false,\n      center: false,\n      webPreferences: {\n        nodeIntegration: false\n      }\n    };\n  }\n\n  get bdServer() {\n    const server = {\n      name: \"BetterDiscord\",\n      online: \"7500+\",\n      members: \"20000+\",\n      categories: [\"community\", \"programming\", \"support\"],\n      description: \"Official BetterDiscord server for support etc\",\n      identifier: \"86004744966914048\",\n      iconUrl: \"https://cdn.discordapp.com/icons/86004744966914048/292e7f6bfff2b71dfd13e508a859aedd.webp\",\n      nativejoin: true,\n      invite_code: \"0Tmfo5ZbORCRqbAd\",\n      pinned: true\n    };\n    const guildList = this.SortedGuildStore.getFlattenedGuildIds();\n    const defaultList = this.AvatarDefaults.DEFAULT_AVATARS;\n    return BDV2.react.createElement(ServerCard, {\n      server: server,\n      pinned: true,\n      join: this.join,\n      guildList: guildList,\n      fallback: defaultList[Math.floor(Math.random() * 5)]\n    });\n  }\n\n  get endPoint() {\n    return \"https://search.discordservers.com\";\n  }\n\n  get joinEndPoint() {\n    return \"https://j.discordservers.com\";\n  }\n\n  get connectEndPoint() {\n    return \"https://join.discordservers.com/connect\";\n  }\n\n  async checkConnection() {\n    const self = this;\n\n    try {\n      const response = await fetch(`https://auth.discordservers.com/info`, {\n        method: \"GET\",\n        credentials: \"include\",\n        mode: \"cors\",\n        headers: {\n          \"Accept\": \"application/json\",\n          \"Content-Type\": \"application/json\"\n        }\n      });\n      const data = await response.json();\n      self.setState({\n        selectedCategory: 0,\n        connection: {\n          state: 2,\n          user: data\n        }\n      });\n      self.search(\"\", true);\n    } catch (error) {\n      console.error(error);\n      self.setState({\n        title: \"Not connected to discordservers.com!\",\n        loading: true,\n        selectedCategory: -1,\n        connection: {\n          state: 1,\n          user: null\n        }\n      });\n    }\n  }\n\n  render() {\n    return BDV2.react.createElement(SidebarView, {\n      ref: \"sbv\"\n    }, this.component);\n  }\n\n  get component() {\n    return {\n      sidebar: {\n        component: this.sidebar\n      },\n      content: {\n        component: this.content\n      },\n      tools: {\n        component: BDV2.react.createElement(Tools, {\n          key: \"pt\",\n          ref: \"tools\",\n          onClick: this.close\n        })\n      }\n    };\n  }\n\n  get sidebar() {\n    return BDV2.react.createElement(\"div\", {\n      className: \"sidebar\",\n      key: \"ps\"\n    }, BDV2.react.createElement(\"div\", {\n      className: \"ui-tab-bar SIDE\"\n    }, BDV2.react.createElement(\"div\", {\n      className: \"ui-tab-bar-header\",\n      style: {\n        fontSize: \"16px\"\n      }\n    }, \"Public Servers\"), BDV2.react.createElement(TabBarSeparator, null), this.searchInput, BDV2.react.createElement(TabBarSeparator, null), BDV2.react.createElement(TabBarHeader, {\n      text: \"Categories\"\n    }), this.categoryButtons.map((value, index) => {\n      return BDV2.react.createElement(TabBarItem, {\n        id: index,\n        onClick: this.changeCategory,\n        key: index,\n        text: value,\n        selected: this.state.selectedCategory === index\n      });\n    }), BDV2.react.createElement(TabBarSeparator, null), this.footer, this.connection));\n  }\n\n  get searchInput() {\n    return BDV2.react.createElement(\"div\", {\n      className: \"ui-form-item\"\n    }, BDV2.react.createElement(\"div\", {\n      className: \"ui-text-input flex-vertical\",\n      style: {\n        width: \"172px\",\n        marginLeft: \"10px\"\n      }\n    }, BDV2.react.createElement(\"input\", {\n      ref: \"searchinput\",\n      onKeyDown: this.searchKeyDown,\n      onChange: () => {},\n      type: \"text\",\n      className: \"input default\",\n      placeholder: \"Search...\",\n      maxLength: \"50\"\n    })));\n  }\n\n  searchKeyDown(e) {\n    const self = this;\n    if (self.state.loading || e.which !== 13) return;\n    self.setState({\n      loading: true,\n      title: \"Loading...\",\n      term: e.target.value\n    });\n    let query = `?term=${e.target.value}`;\n\n    if (self.state.selectedCategory !== 0) {\n      query += `&category=${self.categoryButtons[self.state.selectedCategory]}`;\n    }\n\n    self.search(query, true);\n  }\n\n  get categoryButtons() {\n    return [\"All\", \"FPS Games\", \"MMO Games\", \"Strategy Games\", \"MOBA Games\", \"RPG Games\", \"Tabletop Games\", \"Sandbox Games\", \"Simulation Games\", \"Music\", \"Community\", \"Language\", \"Programming\", \"Other\"];\n  }\n\n  changeCategory(id) {\n    const self = this;\n    if (self.state.loading) return;\n    self.refs.searchinput.value = \"\";\n    self.setState({\n      loading: true,\n      selectedCategory: id,\n      title: \"Loading...\",\n      term: null\n    });\n\n    if (id === 0) {\n      self.search(\"\", true);\n      return;\n    }\n\n    self.search(`?category=${self.categoryButtons[id]}`, true);\n  }\n\n  get content() {\n    const self = this;\n    const guildList = this.SortedGuildStore.getFlattenedGuildIds();\n    const defaultList = this.AvatarDefaults.DEFAULT_AVATARS;\n    if (self.state.connection.state === 1) return self.notConnected;\n    let columnModule = BDModules.get(e => e.contentColumnDefault)[0];\n    return [BDV2.react.createElement(\"div\", {\n      ref: \"content\",\n      key: \"pc\",\n      className: columnModule.contentColumn + \" \" + columnModule.contentColumn + \" content-column default\"\n    }, BDV2.react.createElement(SettingsTitle, {\n      text: self.state.title\n    }), self.bdServer, self.state.servers.map(server => {\n      return BDV2.react.createElement(ServerCard, {\n        key: server.identifier,\n        server: server,\n        join: self.join,\n        guildList: guildList,\n        fallback: defaultList[Math.floor(Math.random() * 5)]\n      });\n    }), self.state.next && BDV2.react.createElement(\"button\", {\n      type: \"button\",\n      onClick: () => {\n        if (self.state.loading) return;\n        self.setState({\n          loading: true\n        });\n        self.search(self.state.next, false);\n      },\n      className: \"ui-button filled brand small grow\",\n      style: {\n        width: \"100%\",\n        marginTop: \"10px\",\n        marginBottom: \"10px\"\n      }\n    }, BDV2.react.createElement(\"div\", {\n      className: \"ui-button-contents\"\n    }, self.state.loading ? \"Loading\" : \"Load More\")), self.state.servers.length > 0 && BDV2.react.createElement(SettingsTitle, {\n      text: self.state.title\n    }))];\n  }\n\n  get notConnected() {\n    const self = this; //return BDV2.react.createElement(SettingsTitle, { text: self.state.title });\n\n    let columnModule = BDModules.get(e => e.contentColumnDefault)[0];\n    return [BDV2.react.createElement(\"div\", {\n      key: \"ncc\",\n      ref: \"content\",\n      className: columnModule.contentColumn + \" \" + columnModule.contentColumn + \" content-column default\"\n    }, BDV2.react.createElement(\"h2\", {\n      className: \"ui-form-title h2 margin-reset margin-bottom-20\"\n    }, \"Not connected to discordservers.com!\", BDV2.react.createElement(\"button\", {\n      onClick: self.connect,\n      type: \"button\",\n      className: \"ui-button filled brand small grow\",\n      style: {\n        display: \"inline-block\",\n        minHeight: \"18px\",\n        marginLeft: \"10px\",\n        lineHeight: \"14px\"\n      }\n    }, BDV2.react.createElement(\"div\", {\n      className: \"ui-button-contents\"\n    }, \"Connect\"))), self.bdServer)];\n  }\n\n  get footer() {\n    return BDV2.react.createElement(\"div\", {\n      className: \"ui-tab-bar-header\"\n    }, BDV2.react.createElement(\"a\", {\n      href: \"https://discordservers.com\",\n      target: \"_blank\"\n    }, \"Discordservers.com\"));\n  }\n\n  get connection() {\n    const self = this;\n    const {\n      connection\n    } = self.state;\n    if (connection.state !== 2) return BDV2.react.createElement(\"span\", null);\n    return BDV2.react.createElement(\"span\", null, BDV2.react.createElement(TabBarSeparator, null), BDV2.react.createElement(\"span\", {\n      style: {\n        color: \"#b9bbbe\",\n        fontSize: \"10px\",\n        marginLeft: \"10px\"\n      }\n    }, \"Connected as: \", `${connection.user.username}#${connection.user.discriminator}`), BDV2.react.createElement(\"div\", {\n      style: {\n        padding: \"5px 10px 0 10px\"\n      }\n    }, BDV2.react.createElement(\"button\", {\n      style: {\n        width: \"100%\",\n        minHeight: \"20px\"\n      },\n      type: \"button\",\n      className: \"ui-button filled brand small grow\"\n    }, BDV2.react.createElement(\"div\", {\n      className: \"ui-button-contents\",\n      onClick: self.connect\n    }, \"Reconnect\"))));\n  }\n\n}"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/ui/publicservers/publicServers.js\n"); + +/***/ }), + +/***/ "./src/ui/publicservers/serverCard.js": +/*!********************************************!*\ + !*** ./src/ui/publicservers/serverCard.js ***! + \********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_ServerCard; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n\nclass V2C_ServerCard extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n if (!this.props.server.iconUrl) this.props.server.iconUrl = this.props.fallback;\n this.state = {\n imageError: false,\n joined: this.props.guildList.includes(this.props.server.identifier)\n };\n }\n\n render() {\n const {\n server\n } = this.props;\n let cardModule = BDModules.get(e => e.card && e.cardPrimary)[0];\n let flexModule = BDModules.get(e => e.flexChild && e._horizontalReverse)[0];\n let wrapModule = BDModules.get(e => e.noWrap && !e.streamerModeEnabled)[0];\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", // cardPrimary-1Hv-to\n {\n className: `${cardModule.card} ${cardModule.cardPrimary} ${BDModules.get(e => e.marginBottom8)[0].marginBottom8} bd-server-card${server.pinned ? \" bd-server-card-pinned\" : \"\"}`\n }, // BDV2.react.createElement(\n // \"div\",\n // { className: \"flex-1xMQg5 flex-1O1GKY horizontal-1ae9ci horizontal-2EEEnY flex-1O1GKY directionRow-3v3tfG justifyStart-2yIZo0 alignStretch-1hwxMa noWrap-3jynv6\" },\n _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"img\", {\n ref: \"img\",\n className: \"bd-server-image\",\n src: server.iconUrl,\n onError: this.handleError.bind(this)\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: flexModule.flexChild + \" bd-server-content\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: flexModule.horizontal + \" \" + wrapModule.noWrap + \" bd-server-header\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"h5\", {\n className: \"h5-18_1nd defaultColor-1_ajX0 margin-reset bd-server-name\"\n }, server.name), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"h5\", {\n className: \"h5-18_1nd defaultColor-1_ajX0 margin-reset bd-server-member-count\"\n }, server.members, \" Members\")), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: flexModule.horizontal + \" \" + wrapModule.noWrap\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"scrollerWrap-2lJEkd scrollerThemed-2oenus themeGhostHairline-DBD-2d scrollerFade-1Ijw5y bd-server-description-container\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"scroller-2FKFPG scroller bd-server-description\"\n }, server.description))), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"flex-1xMQg5 flex-1O1GKY horizontal-1ae9ci horizontal-2EEEnY directionRow-3v3tfG noWrap-3jynv6 bd-server-footer\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"flexChild-faoVW3 bd-server-tags\",\n style: {\n flex: \"1 1 auto\"\n }\n }, server.categories.join(\", \")), this.state.joined && _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"button\", {\n type: \"button\",\n className: \"button-38aScr lookFilled-1Gx00P colorBrand-3pXr91 sizeMin-1mJd1x grow-q77ONN colorGreen-29iAKY\",\n style: {\n minHeight: \"12px\",\n marginTop: \"4px\",\n backgroundColor: \"#3ac15c\"\n }\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-button-contents\"\n }, \"Joined\")), server.error && _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"button\", {\n type: \"button\",\n className: \"button-38aScr lookFilled-1Gx00P colorBrand-3pXr91 sizeMin-1mJd1x grow-q77ONN disabled-9aF2ug\",\n style: {\n minHeight: \"12px\",\n marginTop: \"4px\",\n backgroundColor: \"#c13a3a\"\n }\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-button-contents\"\n }, \"Error\")), !server.error && !this.state.joined && _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"button\", {\n type: \"button\",\n className: \"button-38aScr lookFilled-1Gx00P colorBrand-3pXr91 sizeMin-1mJd1x grow-q77ONN\",\n style: {\n minHeight: \"12px\",\n marginTop: \"4px\"\n },\n onClick: () => {\n this.join();\n }\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-button-contents\"\n }, \"Join\")))) // )\n );\n }\n\n handleError() {\n this.props.server.iconUrl = this.props.fallback;\n this.setState({\n imageError: true\n });\n }\n\n join() {\n this.props.join(this); //this.setState({joined: true});\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvcHVibGljc2VydmVycy9zZXJ2ZXJDYXJkLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQmV0dGVyRGlzY29yZC8uL3NyYy91aS9wdWJsaWNzZXJ2ZXJzL3NlcnZlckNhcmQuanM/MmE0ZiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQkRWMiBmcm9tIFwiLi4vLi4vbW9kdWxlcy92MlwiO1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgVjJDX1NlcnZlckNhcmQgZXh0ZW5kcyBCRFYyLnJlYWN0Q29tcG9uZW50IHtcbiAgY29uc3RydWN0b3IocHJvcHMpIHtcbiAgICBzdXBlcihwcm9wcyk7XG4gICAgaWYgKCF0aGlzLnByb3BzLnNlcnZlci5pY29uVXJsKSB0aGlzLnByb3BzLnNlcnZlci5pY29uVXJsID0gdGhpcy5wcm9wcy5mYWxsYmFjaztcbiAgICB0aGlzLnN0YXRlID0ge1xuICAgICAgaW1hZ2VFcnJvcjogZmFsc2UsXG4gICAgICBqb2luZWQ6IHRoaXMucHJvcHMuZ3VpbGRMaXN0LmluY2x1ZGVzKHRoaXMucHJvcHMuc2VydmVyLmlkZW50aWZpZXIpXG4gICAgfTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7XG4gICAgICBzZXJ2ZXJcbiAgICB9ID0gdGhpcy5wcm9wcztcbiAgICBsZXQgY2FyZE1vZHVsZSA9IEJETW9kdWxlcy5nZXQoZSA9PiBlLmNhcmQgJiYgZS5jYXJkUHJpbWFyeSlbMF07XG4gICAgbGV0IGZsZXhNb2R1bGUgPSBCRE1vZHVsZXMuZ2V0KGUgPT4gZS5mbGV4Q2hpbGQgJiYgZS5faG9yaXpvbnRhbFJldmVyc2UpWzBdO1xuICAgIGxldCB3cmFwTW9kdWxlID0gQkRNb2R1bGVzLmdldChlID0+IGUubm9XcmFwICYmICFlLnN0cmVhbWVyTW9kZUVuYWJsZWQpWzBdO1xuICAgIHJldHVybiBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgLy8gY2FyZFByaW1hcnktMUh2LXRvXG4gICAge1xuICAgICAgY2xhc3NOYW1lOiBgJHtjYXJkTW9kdWxlLmNhcmR9ICR7Y2FyZE1vZHVsZS5jYXJkUHJpbWFyeX0gJHtCRE1vZHVsZXMuZ2V0KGUgPT4gZS5tYXJnaW5Cb3R0b204KVswXS5tYXJnaW5Cb3R0b204fSBiZC1zZXJ2ZXItY2FyZCR7c2VydmVyLnBpbm5lZCA/IFwiIGJkLXNlcnZlci1jYXJkLXBpbm5lZFwiIDogXCJcIn1gXG4gICAgfSwgLy8gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFxuICAgIC8vIFwiZGl2XCIsXG4gICAgLy8geyBjbGFzc05hbWU6IFwiZmxleC0xeE1RZzUgZmxleC0xTzFHS1kgaG9yaXpvbnRhbC0xYWU5Y2kgaG9yaXpvbnRhbC0yRUVFblkgZmxleC0xTzFHS1kgZGlyZWN0aW9uUm93LTN2M3RmRyBqdXN0aWZ5U3RhcnQtMnlJWm8wIGFsaWduU3RyZXRjaC0xaHd4TWEgbm9XcmFwLTNqeW52NlwiIH0sXG4gICAgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiaW1nXCIsIHtcbiAgICAgIHJlZjogXCJpbWdcIixcbiAgICAgIGNsYXNzTmFtZTogXCJiZC1zZXJ2ZXItaW1hZ2VcIixcbiAgICAgIHNyYzogc2VydmVyLmljb25VcmwsXG4gICAgICBvbkVycm9yOiB0aGlzLmhhbmRsZUVycm9yLmJpbmQodGhpcylcbiAgICB9KSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogZmxleE1vZHVsZS5mbGV4Q2hpbGQgKyBcIiBiZC1zZXJ2ZXItY29udGVudFwiXG4gICAgfSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogZmxleE1vZHVsZS5ob3Jpem9udGFsICsgXCIgXCIgKyB3cmFwTW9kdWxlLm5vV3JhcCArIFwiIGJkLXNlcnZlci1oZWFkZXJcIlxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImg1XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJoNS0xOF8xbmQgZGVmYXVsdENvbG9yLTFfYWpYMCBtYXJnaW4tcmVzZXQgYmQtc2VydmVyLW5hbWVcIlxuICAgIH0sIHNlcnZlci5uYW1lKSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiaDVcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcImg1LTE4XzFuZCBkZWZhdWx0Q29sb3ItMV9halgwIG1hcmdpbi1yZXNldCBiZC1zZXJ2ZXItbWVtYmVyLWNvdW50XCJcbiAgICB9LCBzZXJ2ZXIubWVtYmVycywgXCIgTWVtYmVyc1wiKSksIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IGZsZXhNb2R1bGUuaG9yaXpvbnRhbCArIFwiIFwiICsgd3JhcE1vZHVsZS5ub1dyYXBcbiAgICB9LCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcInNjcm9sbGVyV3JhcC0ybEpFa2Qgc2Nyb2xsZXJUaGVtZWQtMm9lbnVzIHRoZW1lR2hvc3RIYWlybGluZS1EQkQtMmQgc2Nyb2xsZXJGYWRlLTFJanc1eSBiZC1zZXJ2ZXItZGVzY3JpcHRpb24tY29udGFpbmVyXCJcbiAgICB9LCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcInNjcm9sbGVyLTJGS0ZQRyBzY3JvbGxlciBiZC1zZXJ2ZXItZGVzY3JpcHRpb25cIlxuICAgIH0sIHNlcnZlci5kZXNjcmlwdGlvbikpKSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJmbGV4LTF4TVFnNSBmbGV4LTFPMUdLWSBob3Jpem9udGFsLTFhZTljaSBob3Jpem9udGFsLTJFRUVuWSBkaXJlY3Rpb25Sb3ctM3YzdGZHIG5vV3JhcC0zanludjYgYmQtc2VydmVyLWZvb3RlclwiXG4gICAgfSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJmbGV4Q2hpbGQtZmFvVlczIGJkLXNlcnZlci10YWdzXCIsXG4gICAgICBzdHlsZToge1xuICAgICAgICBmbGV4OiBcIjEgMSBhdXRvXCJcbiAgICAgIH1cbiAgICB9LCBzZXJ2ZXIuY2F0ZWdvcmllcy5qb2luKFwiLCBcIikpLCB0aGlzLnN0YXRlLmpvaW5lZCAmJiBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJidXR0b25cIiwge1xuICAgICAgdHlwZTogXCJidXR0b25cIixcbiAgICAgIGNsYXNzTmFtZTogXCJidXR0b24tMzhhU2NyIGxvb2tGaWxsZWQtMUd4MDBQIGNvbG9yQnJhbmQtM3BYcjkxIHNpemVNaW4tMW1KZDF4IGdyb3ctcTc3T05OIGNvbG9yR3JlZW4tMjlpQUtZXCIsXG4gICAgICBzdHlsZToge1xuICAgICAgICBtaW5IZWlnaHQ6IFwiMTJweFwiLFxuICAgICAgICBtYXJnaW5Ub3A6IFwiNHB4XCIsXG4gICAgICAgIGJhY2tncm91bmRDb2xvcjogXCIjM2FjMTVjXCJcbiAgICAgIH1cbiAgICB9LCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcInVpLWJ1dHRvbi1jb250ZW50c1wiXG4gICAgfSwgXCJKb2luZWRcIikpLCBzZXJ2ZXIuZXJyb3IgJiYgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiYnV0dG9uXCIsIHtcbiAgICAgIHR5cGU6IFwiYnV0dG9uXCIsXG4gICAgICBjbGFzc05hbWU6IFwiYnV0dG9uLTM4YVNjciBsb29rRmlsbGVkLTFHeDAwUCBjb2xvckJyYW5kLTNwWHI5MSBzaXplTWluLTFtSmQxeCBncm93LXE3N09OTiBkaXNhYmxlZC05YUYydWdcIixcbiAgICAgIHN0eWxlOiB7XG4gICAgICAgIG1pbkhlaWdodDogXCIxMnB4XCIsXG4gICAgICAgIG1hcmdpblRvcDogXCI0cHhcIixcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiBcIiNjMTNhM2FcIlxuICAgICAgfVxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IFwidWktYnV0dG9uLWNvbnRlbnRzXCJcbiAgICB9LCBcIkVycm9yXCIpKSwgIXNlcnZlci5lcnJvciAmJiAhdGhpcy5zdGF0ZS5qb2luZWQgJiYgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiYnV0dG9uXCIsIHtcbiAgICAgIHR5cGU6IFwiYnV0dG9uXCIsXG4gICAgICBjbGFzc05hbWU6IFwiYnV0dG9uLTM4YVNjciBsb29rRmlsbGVkLTFHeDAwUCBjb2xvckJyYW5kLTNwWHI5MSBzaXplTWluLTFtSmQxeCBncm93LXE3N09OTlwiLFxuICAgICAgc3R5bGU6IHtcbiAgICAgICAgbWluSGVpZ2h0OiBcIjEycHhcIixcbiAgICAgICAgbWFyZ2luVG9wOiBcIjRweFwiXG4gICAgICB9LFxuICAgICAgb25DbGljazogKCkgPT4ge1xuICAgICAgICB0aGlzLmpvaW4oKTtcbiAgICAgIH1cbiAgICB9LCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcInVpLWJ1dHRvbi1jb250ZW50c1wiXG4gICAgfSwgXCJKb2luXCIpKSkpIC8vIClcbiAgICApO1xuICB9XG5cbiAgaGFuZGxlRXJyb3IoKSB7XG4gICAgdGhpcy5wcm9wcy5zZXJ2ZXIuaWNvblVybCA9IHRoaXMucHJvcHMuZmFsbGJhY2s7XG4gICAgdGhpcy5zZXRTdGF0ZSh7XG4gICAgICBpbWFnZUVycm9yOiB0cnVlXG4gICAgfSk7XG4gIH1cblxuICBqb2luKCkge1xuICAgIHRoaXMucHJvcHMuam9pbih0aGlzKTsgLy90aGlzLnNldFN0YXRlKHtqb2luZWQ6IHRydWV9KTtcbiAgfVxuXG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/ui/publicservers/serverCard.js\n"); + +/***/ }), + +/***/ "./src/ui/publicservers/sidebarView.js": +/*!*********************************************!*\ + !*** ./src/ui/publicservers/sidebarView.js ***! + \*********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_SidebarView; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _scroller__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../scroller */ \"./src/ui/scroller.js\");\n\n\nclass V2C_SidebarView extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n }\n\n render() {\n const {\n sidebar,\n content,\n tools\n } = this.props.children;\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"standardSidebarView-3F1I7i ui-standard-sidebar-view\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"sidebarRegion-VFTUkN sidebar-region\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_scroller__WEBPACK_IMPORTED_MODULE_1__[\"default\"], {\n key: \"sidebarScroller\",\n ref: \"sidebarScroller\",\n sidebar: true,\n fade: sidebar.fade || true,\n dark: sidebar.dark || true\n }, sidebar.component)), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"contentRegion-3nDuYy content-region\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"contentTransitionWrap-3hqOEW content-transition-wrap\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"scrollerWrap-2lJEkd firefoxFixScrollFlex-cnI2ix contentRegionScrollerWrap-3YZXdm content-region-scroller-wrap scrollerThemed-2oenus themeGhost-28MSn0 scrollerTrack-1ZIpsv\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"scroller-2FKFPG firefoxFixScrollFlex-cnI2ix contentRegionScroller-26nc1e content-region-scroller scroller\",\n ref: \"contentScroller\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"contentColumn-2hrIYH contentColumnDefault-1VQkGM content-column default\"\n }, content.component), tools.component)))));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvcHVibGljc2VydmVycy9zaWRlYmFyVmlldy5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvcHVibGljc2VydmVycy9zaWRlYmFyVmlldy5qcz85OTE1Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi8uLi9tb2R1bGVzL3YyXCI7XG5pbXBvcnQgU2Nyb2xsZXIgZnJvbSBcIi4uL3Njcm9sbGVyXCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWMkNfU2lkZWJhclZpZXcgZXh0ZW5kcyBCRFYyLnJlYWN0Q29tcG9uZW50IHtcbiAgY29uc3RydWN0b3IocHJvcHMpIHtcbiAgICBzdXBlcihwcm9wcyk7XG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgY29uc3Qge1xuICAgICAgc2lkZWJhcixcbiAgICAgIGNvbnRlbnQsXG4gICAgICB0b29sc1xuICAgIH0gPSB0aGlzLnByb3BzLmNoaWxkcmVuO1xuICAgIHJldHVybiBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcInN0YW5kYXJkU2lkZWJhclZpZXctM0YxSTdpIHVpLXN0YW5kYXJkLXNpZGViYXItdmlld1wiXG4gICAgfSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJzaWRlYmFyUmVnaW9uLVZGVFVrTiBzaWRlYmFyLXJlZ2lvblwiXG4gICAgfSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFNjcm9sbGVyLCB7XG4gICAgICBrZXk6IFwic2lkZWJhclNjcm9sbGVyXCIsXG4gICAgICByZWY6IFwic2lkZWJhclNjcm9sbGVyXCIsXG4gICAgICBzaWRlYmFyOiB0cnVlLFxuICAgICAgZmFkZTogc2lkZWJhci5mYWRlIHx8IHRydWUsXG4gICAgICBkYXJrOiBzaWRlYmFyLmRhcmsgfHwgdHJ1ZVxuICAgIH0sIHNpZGViYXIuY29tcG9uZW50KSksIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IFwiY29udGVudFJlZ2lvbi0zbkR1WXkgY29udGVudC1yZWdpb25cIlxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IFwiY29udGVudFRyYW5zaXRpb25XcmFwLTNocU9FVyBjb250ZW50LXRyYW5zaXRpb24td3JhcFwiXG4gICAgfSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJzY3JvbGxlcldyYXAtMmxKRWtkIGZpcmVmb3hGaXhTY3JvbGxGbGV4LWNuSTJpeCBjb250ZW50UmVnaW9uU2Nyb2xsZXJXcmFwLTNZWlhkbSBjb250ZW50LXJlZ2lvbi1zY3JvbGxlci13cmFwIHNjcm9sbGVyVGhlbWVkLTJvZW51cyB0aGVtZUdob3N0LTI4TVNuMCBzY3JvbGxlclRyYWNrLTFaSXBzdlwiXG4gICAgfSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJzY3JvbGxlci0yRktGUEcgZmlyZWZveEZpeFNjcm9sbEZsZXgtY25JMml4IGNvbnRlbnRSZWdpb25TY3JvbGxlci0yNm5jMWUgY29udGVudC1yZWdpb24tc2Nyb2xsZXIgc2Nyb2xsZXJcIixcbiAgICAgIHJlZjogXCJjb250ZW50U2Nyb2xsZXJcIlxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IFwiY29udGVudENvbHVtbi0yaHJJWUggY29udGVudENvbHVtbkRlZmF1bHQtMVZRa0dNIGNvbnRlbnQtY29sdW1uIGRlZmF1bHRcIlxuICAgIH0sIGNvbnRlbnQuY29tcG9uZW50KSwgdG9vbHMuY29tcG9uZW50KSkpKSk7XG4gIH1cblxufSJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/ui/publicservers/sidebarView.js\n"); + +/***/ }), + +/***/ "./src/ui/reloadIcon.js": +/*!******************************!*\ + !*** ./src/ui/reloadIcon.js ***! + \******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_ReloadIcon; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass V2C_ReloadIcon extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n }\n\n render() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"svg\", {\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 24 24\",\n fill: \"#dcddde\",\n className: \"bd-reload \" + this.props.className,\n onClick: this.props.onClick,\n style: {\n width: this.props.size || \"24px\",\n height: this.props.size || \"24px\"\n }\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"path\", {\n d: \"M17.65 6.35C16.2 4.9 14.21 4 12 4c-4.42 0-7.99 3.58-7.99 8s3.57 8 7.99 8c3.73 0 6.84-2.55 7.73-6h-2.08c-.82 2.33-3.04 4-5.65 4-3.31 0-6-2.69-6-6s2.69-6 6-6c1.66 0 3.14.69 4.22 1.78L13 11h7V4l-2.35 2.35z\"\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"path\", {\n fill: \"none\",\n d: \"M0 0h24v24H0z\"\n }));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvcmVsb2FkSWNvbi5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvcmVsb2FkSWNvbi5qcz9iZTcwIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi9tb2R1bGVzL3YyXCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWMkNfUmVsb2FkSWNvbiBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwic3ZnXCIsIHtcbiAgICAgIHhtbG5zOiBcImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIsXG4gICAgICB2aWV3Qm94OiBcIjAgMCAyNCAyNFwiLFxuICAgICAgZmlsbDogXCIjZGNkZGRlXCIsXG4gICAgICBjbGFzc05hbWU6IFwiYmQtcmVsb2FkIFwiICsgdGhpcy5wcm9wcy5jbGFzc05hbWUsXG4gICAgICBvbkNsaWNrOiB0aGlzLnByb3BzLm9uQ2xpY2ssXG4gICAgICBzdHlsZToge1xuICAgICAgICB3aWR0aDogdGhpcy5wcm9wcy5zaXplIHx8IFwiMjRweFwiLFxuICAgICAgICBoZWlnaHQ6IHRoaXMucHJvcHMuc2l6ZSB8fCBcIjI0cHhcIlxuICAgICAgfVxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcInBhdGhcIiwge1xuICAgICAgZDogXCJNMTcuNjUgNi4zNUMxNi4yIDQuOSAxNC4yMSA0IDEyIDRjLTQuNDIgMC03Ljk5IDMuNTgtNy45OSA4czMuNTcgOCA3Ljk5IDhjMy43MyAwIDYuODQtMi41NSA3LjczLTZoLTIuMDhjLS44MiAyLjMzLTMuMDQgNC01LjY1IDQtMy4zMSAwLTYtMi42OS02LTZzMi42OS02IDYtNmMxLjY2IDAgMy4xNC42OSA0LjIyIDEuNzhMMTMgMTFoN1Y0bC0yLjM1IDIuMzV6XCJcbiAgICB9KSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwicGF0aFwiLCB7XG4gICAgICBmaWxsOiBcIm5vbmVcIixcbiAgICAgIGQ6IFwiTTAgMGgyNHYyNEgwelwiXG4gICAgfSkpO1xuICB9XG5cbn0iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/reloadIcon.js\n"); + +/***/ }), + +/***/ "./src/ui/scroller.js": +/*!****************************!*\ + !*** ./src/ui/scroller.js ***! + \****************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_Scroller; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass V2C_Scroller extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n }\n\n render() {\n //scrollerWrap-2lJEkd scrollerThemed-2oenus themeGhostHairline-DBD-2d scrollerFade-1Ijw5y\n let scrollerModule1 = BDModules.get(e => e.scrollerHorizontal)[0];\n let scrollerModule2 = BDModules.get(e => e.sidebarRegionScroller)[0];\n let wrapperClass = `${scrollerModule1.scrollerWrap} ${scrollerModule1.scrollerThemed} ${scrollerModule1.themeGhostHairline}${this.props.fade ? \" \" + scrollerModule1.scrollerFade : \"\"}`;\n let scrollerClass = scrollerModule1.scroller + \" scroller\";\n /* fuck */\n\n if (this.props.sidebar) scrollerClass += ` ${scrollerModule2.sidebarRegionScroller} sidebar-region-scroller`;\n\n if (this.props.contentColumn) {\n scrollerClass += \" \" + scrollerModule2.contentRegionScroller + \" content-region-scroller\";\n /* fuck */\n\n wrapperClass = `${scrollerModule1.scrollerWrap} ${scrollerModule2.contentRegionScrollerWrap} content-region-scroller-wrap ${scrollerModule1.scrollerThemed} ${scrollerModule1.themeGhost} ${scrollerModule1.scrollerTrack}`;\n }\n\n const {\n children\n } = this.props;\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n key: \"scrollerwrap\",\n className: wrapperClass\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n key: \"scroller\",\n ref: \"scroller\",\n className: scrollerClass\n }, children));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvc2Nyb2xsZXIuanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL3VpL3Njcm9sbGVyLmpzPzQwNzciXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJEVjIgZnJvbSBcIi4uL21vZHVsZXMvdjJcIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFYyQ19TY3JvbGxlciBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICAvL3Njcm9sbGVyV3JhcC0ybEpFa2Qgc2Nyb2xsZXJUaGVtZWQtMm9lbnVzIHRoZW1lR2hvc3RIYWlybGluZS1EQkQtMmQgc2Nyb2xsZXJGYWRlLTFJanc1eVxuICAgIGxldCBzY3JvbGxlck1vZHVsZTEgPSBCRE1vZHVsZXMuZ2V0KGUgPT4gZS5zY3JvbGxlckhvcml6b250YWwpWzBdO1xuICAgIGxldCBzY3JvbGxlck1vZHVsZTIgPSBCRE1vZHVsZXMuZ2V0KGUgPT4gZS5zaWRlYmFyUmVnaW9uU2Nyb2xsZXIpWzBdO1xuICAgIGxldCB3cmFwcGVyQ2xhc3MgPSBgJHtzY3JvbGxlck1vZHVsZTEuc2Nyb2xsZXJXcmFwfSAke3Njcm9sbGVyTW9kdWxlMS5zY3JvbGxlclRoZW1lZH0gJHtzY3JvbGxlck1vZHVsZTEudGhlbWVHaG9zdEhhaXJsaW5lfSR7dGhpcy5wcm9wcy5mYWRlID8gXCIgXCIgKyBzY3JvbGxlck1vZHVsZTEuc2Nyb2xsZXJGYWRlIDogXCJcIn1gO1xuICAgIGxldCBzY3JvbGxlckNsYXNzID0gc2Nyb2xsZXJNb2R1bGUxLnNjcm9sbGVyICsgXCIgc2Nyb2xsZXJcIjtcbiAgICAvKiBmdWNrICovXG5cbiAgICBpZiAodGhpcy5wcm9wcy5zaWRlYmFyKSBzY3JvbGxlckNsYXNzICs9IGAgJHtzY3JvbGxlck1vZHVsZTIuc2lkZWJhclJlZ2lvblNjcm9sbGVyfSBzaWRlYmFyLXJlZ2lvbi1zY3JvbGxlcmA7XG5cbiAgICBpZiAodGhpcy5wcm9wcy5jb250ZW50Q29sdW1uKSB7XG4gICAgICBzY3JvbGxlckNsYXNzICs9IFwiIFwiICsgc2Nyb2xsZXJNb2R1bGUyLmNvbnRlbnRSZWdpb25TY3JvbGxlciArIFwiIGNvbnRlbnQtcmVnaW9uLXNjcm9sbGVyXCI7XG4gICAgICAvKiBmdWNrICovXG5cbiAgICAgIHdyYXBwZXJDbGFzcyA9IGAke3Njcm9sbGVyTW9kdWxlMS5zY3JvbGxlcldyYXB9ICR7c2Nyb2xsZXJNb2R1bGUyLmNvbnRlbnRSZWdpb25TY3JvbGxlcldyYXB9IGNvbnRlbnQtcmVnaW9uLXNjcm9sbGVyLXdyYXAgICR7c2Nyb2xsZXJNb2R1bGUxLnNjcm9sbGVyVGhlbWVkfSAke3Njcm9sbGVyTW9kdWxlMS50aGVtZUdob3N0fSAke3Njcm9sbGVyTW9kdWxlMS5zY3JvbGxlclRyYWNrfWA7XG4gICAgfVxuXG4gICAgY29uc3Qge1xuICAgICAgY2hpbGRyZW5cbiAgICB9ID0gdGhpcy5wcm9wcztcbiAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGtleTogXCJzY3JvbGxlcndyYXBcIixcbiAgICAgIGNsYXNzTmFtZTogd3JhcHBlckNsYXNzXG4gICAgfSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGtleTogXCJzY3JvbGxlclwiLFxuICAgICAgcmVmOiBcInNjcm9sbGVyXCIsXG4gICAgICBjbGFzc05hbWU6IHNjcm9sbGVyQ2xhc3NcbiAgICB9LCBjaGlsZHJlbikpO1xuICB9XG5cbn0iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/ui/scroller.js\n"); + +/***/ }), + +/***/ "./src/ui/sectionedSettingsPanel.js": +/*!******************************************!*\ + !*** ./src/ui/sectionedSettingsPanel.js ***! + \******************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_SectionedSettingsPanel; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _settingsGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./settingsGroup */ \"./src/ui/settingsGroup.js\");\n\n\nclass V2C_SectionedSettingsPanel extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n }\n\n render() {\n let columnModule = BDModules.get(e => e.contentColumnDefault)[0];\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: columnModule.contentColumn + \" \" + columnModule.contentColumnDefault + \" content-column default\"\n }, this.props.sections.map(section => {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_settingsGroup__WEBPACK_IMPORTED_MODULE_1__[\"default\"], Object.assign({}, section, {\n onChange: this.props.onChange\n }));\n }));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvc2VjdGlvbmVkU2V0dGluZ3NQYW5lbC5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvc2VjdGlvbmVkU2V0dGluZ3NQYW5lbC5qcz9hZjUyIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi9tb2R1bGVzL3YyXCI7XG5pbXBvcnQgU2V0dGluZ3NHcm91cCBmcm9tIFwiLi9zZXR0aW5nc0dyb3VwXCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWMkNfU2VjdGlvbmVkU2V0dGluZ3NQYW5lbCBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBsZXQgY29sdW1uTW9kdWxlID0gQkRNb2R1bGVzLmdldChlID0+IGUuY29udGVudENvbHVtbkRlZmF1bHQpWzBdO1xuICAgIHJldHVybiBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBjb2x1bW5Nb2R1bGUuY29udGVudENvbHVtbiArIFwiIFwiICsgY29sdW1uTW9kdWxlLmNvbnRlbnRDb2x1bW5EZWZhdWx0ICsgXCIgY29udGVudC1jb2x1bW4gZGVmYXVsdFwiXG4gICAgfSwgdGhpcy5wcm9wcy5zZWN0aW9ucy5tYXAoc2VjdGlvbiA9PiB7XG4gICAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFNldHRpbmdzR3JvdXAsIE9iamVjdC5hc3NpZ24oe30sIHNlY3Rpb24sIHtcbiAgICAgICAgb25DaGFuZ2U6IHRoaXMucHJvcHMub25DaGFuZ2VcbiAgICAgIH0pKTtcbiAgICB9KSk7XG4gIH1cblxufSJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/sectionedSettingsPanel.js\n"); + +/***/ }), + +/***/ "./src/ui/settingsGroup.js": +/*!*********************************!*\ + !*** ./src/ui/settingsGroup.js ***! + \*********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_SettingsGroup; });\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _settingsTitle__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./settingsTitle */ \"./src/ui/settingsTitle.js\");\n/* harmony import */ var _switch__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./switch */ \"./src/ui/switch.js\");\n\n\n\n\nclass V2C_SettingsGroup extends _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n }\n\n render() {\n const {\n title,\n settings,\n button\n } = this.props;\n const buttonComponent = button ? _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"button\", {\n key: \"title-button\",\n className: \"bd-pfbtn\",\n onClick: button.onClick\n }, button.title) : null;\n return [_modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(_settingsTitle__WEBPACK_IMPORTED_MODULE_2__[\"default\"], {\n text: title\n }), buttonComponent, settings.map(setting => {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(_switch__WEBPACK_IMPORTED_MODULE_3__[\"default\"], {\n id: setting.id,\n key: setting.id,\n data: setting,\n checked: _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][setting.id],\n onChange: (id, checked) => {\n this.props.onChange(id, checked);\n }\n });\n })];\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvc2V0dGluZ3NHcm91cC5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvc2V0dGluZ3NHcm91cC5qcz8zYzIzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHNldHRpbmdzQ29va2llIH0gZnJvbSBcIi4uLzBnbG9iYWxzXCI7XG5pbXBvcnQgQkRWMiBmcm9tIFwiLi4vbW9kdWxlcy92MlwiO1xuaW1wb3J0IFNldHRpbmdzVGl0bGUgZnJvbSBcIi4vc2V0dGluZ3NUaXRsZVwiO1xuaW1wb3J0IFN3aXRjaCBmcm9tIFwiLi9zd2l0Y2hcIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFYyQ19TZXR0aW5nc0dyb3VwIGV4dGVuZHMgQkRWMi5yZWFjdENvbXBvbmVudCB7XG4gIGNvbnN0cnVjdG9yKHByb3BzKSB7XG4gICAgc3VwZXIocHJvcHMpO1xuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHtcbiAgICAgIHRpdGxlLFxuICAgICAgc2V0dGluZ3MsXG4gICAgICBidXR0b25cbiAgICB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBidXR0b25Db21wb25lbnQgPSBidXR0b24gPyBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJidXR0b25cIiwge1xuICAgICAga2V5OiBcInRpdGxlLWJ1dHRvblwiLFxuICAgICAgY2xhc3NOYW1lOiBcImJkLXBmYnRuXCIsXG4gICAgICBvbkNsaWNrOiBidXR0b24ub25DbGlja1xuICAgIH0sIGJ1dHRvbi50aXRsZSkgOiBudWxsO1xuICAgIHJldHVybiBbQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFNldHRpbmdzVGl0bGUsIHtcbiAgICAgIHRleHQ6IHRpdGxlXG4gICAgfSksIGJ1dHRvbkNvbXBvbmVudCwgc2V0dGluZ3MubWFwKHNldHRpbmcgPT4ge1xuICAgICAgcmV0dXJuIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChTd2l0Y2gsIHtcbiAgICAgICAgaWQ6IHNldHRpbmcuaWQsXG4gICAgICAgIGtleTogc2V0dGluZy5pZCxcbiAgICAgICAgZGF0YTogc2V0dGluZyxcbiAgICAgICAgY2hlY2tlZDogc2V0dGluZ3NDb29raWVbc2V0dGluZy5pZF0sXG4gICAgICAgIG9uQ2hhbmdlOiAoaWQsIGNoZWNrZWQpID0+IHtcbiAgICAgICAgICB0aGlzLnByb3BzLm9uQ2hhbmdlKGlkLCBjaGVja2VkKTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfSldO1xuICB9XG5cbn0iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/settingsGroup.js\n"); + +/***/ }), + +/***/ "./src/ui/settingsPanel.js": +/*!*********************************!*\ + !*** ./src/ui/settingsPanel.js ***! + \*********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_SettingsPanel; });\n/* harmony import */ var _0globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../0globals */ \"./src/0globals.js\");\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _settingsTitle__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./settingsTitle */ \"./src/ui/settingsTitle.js\");\n/* harmony import */ var _switch__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./switch */ \"./src/ui/switch.js\");\n\n\n\n\nclass V2C_SettingsPanel extends _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n }\n\n render() {\n const {\n settings\n } = this.props;\n let columnModule = BDModules.get(e => e.contentColumnDefault)[0];\n return _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"div\", {\n className: columnModule.contentColumn + \" \" + columnModule.contentColumnDefault + \" content-column default\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(_settingsTitle__WEBPACK_IMPORTED_MODULE_2__[\"default\"], {\n text: this.props.title\n }), this.props.button && _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(\"button\", {\n key: \"title-button\",\n className: \"bd-pfbtn\",\n onClick: this.props.button.onClick\n }, this.props.button.title), settings.map(setting => {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_1__[\"default\"].react.createElement(_switch__WEBPACK_IMPORTED_MODULE_3__[\"default\"], {\n id: setting.id,\n key: setting.id,\n data: setting,\n checked: _0globals__WEBPACK_IMPORTED_MODULE_0__[\"settingsCookie\"][setting.id],\n onChange: (id, checked) => {\n this.props.onChange(id, checked);\n }\n });\n }));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvc2V0dGluZ3NQYW5lbC5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvc2V0dGluZ3NQYW5lbC5qcz81NzYwIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHNldHRpbmdzQ29va2llIH0gZnJvbSBcIi4uLzBnbG9iYWxzXCI7XG5pbXBvcnQgQkRWMiBmcm9tIFwiLi4vbW9kdWxlcy92MlwiO1xuaW1wb3J0IFNldHRpbmdzVGl0bGUgZnJvbSBcIi4vc2V0dGluZ3NUaXRsZVwiO1xuaW1wb3J0IFN3aXRjaCBmcm9tIFwiLi9zd2l0Y2hcIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFYyQ19TZXR0aW5nc1BhbmVsIGV4dGVuZHMgQkRWMi5yZWFjdENvbXBvbmVudCB7XG4gIGNvbnN0cnVjdG9yKHByb3BzKSB7XG4gICAgc3VwZXIocHJvcHMpO1xuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHtcbiAgICAgIHNldHRpbmdzXG4gICAgfSA9IHRoaXMucHJvcHM7XG4gICAgbGV0IGNvbHVtbk1vZHVsZSA9IEJETW9kdWxlcy5nZXQoZSA9PiBlLmNvbnRlbnRDb2x1bW5EZWZhdWx0KVswXTtcbiAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogY29sdW1uTW9kdWxlLmNvbnRlbnRDb2x1bW4gKyBcIiBcIiArIGNvbHVtbk1vZHVsZS5jb250ZW50Q29sdW1uRGVmYXVsdCArIFwiIGNvbnRlbnQtY29sdW1uIGRlZmF1bHRcIlxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChTZXR0aW5nc1RpdGxlLCB7XG4gICAgICB0ZXh0OiB0aGlzLnByb3BzLnRpdGxlXG4gICAgfSksIHRoaXMucHJvcHMuYnV0dG9uICYmIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImJ1dHRvblwiLCB7XG4gICAgICBrZXk6IFwidGl0bGUtYnV0dG9uXCIsXG4gICAgICBjbGFzc05hbWU6IFwiYmQtcGZidG5cIixcbiAgICAgIG9uQ2xpY2s6IHRoaXMucHJvcHMuYnV0dG9uLm9uQ2xpY2tcbiAgICB9LCB0aGlzLnByb3BzLmJ1dHRvbi50aXRsZSksIHNldHRpbmdzLm1hcChzZXR0aW5nID0+IHtcbiAgICAgIHJldHVybiBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoU3dpdGNoLCB7XG4gICAgICAgIGlkOiBzZXR0aW5nLmlkLFxuICAgICAgICBrZXk6IHNldHRpbmcuaWQsXG4gICAgICAgIGRhdGE6IHNldHRpbmcsXG4gICAgICAgIGNoZWNrZWQ6IHNldHRpbmdzQ29va2llW3NldHRpbmcuaWRdLFxuICAgICAgICBvbkNoYW5nZTogKGlkLCBjaGVja2VkKSA9PiB7XG4gICAgICAgICAgdGhpcy5wcm9wcy5vbkNoYW5nZShpZCwgY2hlY2tlZCk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH0pKTtcbiAgfVxuXG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/settingsPanel.js\n"); + +/***/ }), + +/***/ "./src/ui/settingsTitle.js": +/*!*********************************!*\ + !*** ./src/ui/settingsTitle.js ***! + \*********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_SettingsTitle; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass V2C_SettingsTitle extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n } //h2-2gWE-o title-3sZWYQ size16-14cGz5 height20-mO2eIN weightSemiBold-NJexzi da-h2 da-title da-size16 da-height20 da-weightSemiBold defaultColor-1_ajX0 da-defaultColor marginTop60-3PGbtK da-marginTop60 marginBottom20-32qID7 da-marginBottom20\n\n\n render() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"h2\", {\n className: \"ui-form-title h2 margin-reset margin-bottom-20 marginTop60-3PGbtK da-marginTop6\"\n }, this.props.text);\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvc2V0dGluZ3NUaXRsZS5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvc2V0dGluZ3NUaXRsZS5qcz9iMjZmIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi9tb2R1bGVzL3YyXCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWMkNfU2V0dGluZ3NUaXRsZSBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgfSAvL2gyLTJnV0UtbyB0aXRsZS0zc1pXWVEgc2l6ZTE2LTE0Y0d6NSBoZWlnaHQyMC1tTzJlSU4gd2VpZ2h0U2VtaUJvbGQtTkpleHppIGRhLWgyIGRhLXRpdGxlIGRhLXNpemUxNiBkYS1oZWlnaHQyMCBkYS13ZWlnaHRTZW1pQm9sZCBkZWZhdWx0Q29sb3ItMV9halgwIGRhLWRlZmF1bHRDb2xvciBtYXJnaW5Ub3A2MC0zUEdidEsgZGEtbWFyZ2luVG9wNjAgbWFyZ2luQm90dG9tMjAtMzJxSUQ3IGRhLW1hcmdpbkJvdHRvbTIwXG5cblxuICByZW5kZXIoKSB7XG4gICAgcmV0dXJuIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImgyXCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJ1aS1mb3JtLXRpdGxlIGgyIG1hcmdpbi1yZXNldCBtYXJnaW4tYm90dG9tLTIwIG1hcmdpblRvcDYwLTNQR2J0SyBkYS1tYXJnaW5Ub3A2XCJcbiAgICB9LCB0aGlzLnByb3BzLnRleHQpO1xuICB9XG5cbn0iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/settingsTitle.js\n"); + +/***/ }), + +/***/ "./src/ui/sidebar.js": +/*!***************************!*\ + !*** ./src/ui/sidebar.js ***! + \***************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_SideBar; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _tabBarSeparator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./tabBarSeparator */ \"./src/ui/tabBarSeparator.js\");\n/* harmony import */ var _tabBarHeader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./tabBarHeader */ \"./src/ui/tabBarHeader.js\");\n/* harmony import */ var _tabBarItem__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./tabBarItem */ \"./src/ui/tabBarItem.js\");\n\n\n\n\nclass V2C_SideBar extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n const si = document.querySelector(\"[class*=side-] > [class*=selected]\");\n if (si) this.scn = si.className;\n const ns = document.querySelector(\"[class*=side-] > [class*='item-']:not([class*=selected])\");\n if (ns) this.nscn = ns.className;\n const tabs = document.querySelectorAll(\"[class*='side-'] > [class*='item-']\");\n\n for (const element of tabs) {\n element.addEventListener(\"click\", () => {\n this.setState({\n selected: null\n });\n });\n }\n\n this.setInitialState();\n this.onClick = this.onClick.bind(this);\n this.setSelected = this.setSelected.bind(this);\n }\n\n setInitialState() {\n const self = this;\n self.state = {\n selected: null,\n items: self.props.items\n };\n const initialSelection = self.props.items.find(item => {\n return item.selected;\n });\n\n if (initialSelection) {\n self.state.selected = initialSelection.id;\n }\n }\n\n render() {\n const self = this;\n const {\n headerText\n } = self.props;\n const {\n items,\n selected\n } = self.state;\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", null, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_tabBarSeparator__WEBPACK_IMPORTED_MODULE_1__[\"default\"], null), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_tabBarHeader__WEBPACK_IMPORTED_MODULE_2__[\"default\"], {\n text: headerText,\n button: this.props.headerButton\n }), items.map(item => {\n const {\n id,\n text\n } = item;\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_tabBarItem__WEBPACK_IMPORTED_MODULE_3__[\"default\"], {\n key: id,\n selected: selected === id,\n text: text,\n id: id,\n onClick: self.onClick\n });\n }));\n }\n\n setSelected(e) {\n e.target.className = this.scn;\n }\n\n onClick(id) {\n const si = document.querySelector(\"[class*=side] > [class*=selected]\");\n\n if (si) {\n si.removeEventListener(\"click\", this.setSelected);\n si.addEventListener(\"click\", this.setSelected);\n si.className = this.nscn;\n }\n\n this.setState({\n selected: null\n });\n this.setState({\n selected: id\n });\n if (this.props.onClick) this.props.onClick(id);\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvc2lkZWJhci5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvc2lkZWJhci5qcz9lYjY1Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi9tb2R1bGVzL3YyXCI7XG5pbXBvcnQgVGFiQmFyU2VwYXJhdG9yIGZyb20gXCIuL3RhYkJhclNlcGFyYXRvclwiO1xuaW1wb3J0IFRhYkJhckhlYWRlciBmcm9tIFwiLi90YWJCYXJIZWFkZXJcIjtcbmltcG9ydCBUYWJCYXJJdGVtIGZyb20gXCIuL3RhYkJhckl0ZW1cIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFYyQ19TaWRlQmFyIGV4dGVuZHMgQkRWMi5yZWFjdENvbXBvbmVudCB7XG4gIGNvbnN0cnVjdG9yKHByb3BzKSB7XG4gICAgc3VwZXIocHJvcHMpO1xuICAgIGNvbnN0IHNpID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvcihcIltjbGFzcyo9c2lkZS1dID4gW2NsYXNzKj1zZWxlY3RlZF1cIik7XG4gICAgaWYgKHNpKSB0aGlzLnNjbiA9IHNpLmNsYXNzTmFtZTtcbiAgICBjb25zdCBucyA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoXCJbY2xhc3MqPXNpZGUtXSA+IFtjbGFzcyo9J2l0ZW0tJ106bm90KFtjbGFzcyo9c2VsZWN0ZWRdKVwiKTtcbiAgICBpZiAobnMpIHRoaXMubnNjbiA9IG5zLmNsYXNzTmFtZTtcbiAgICBjb25zdCB0YWJzID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbChcIltjbGFzcyo9J3NpZGUtJ10gPiBbY2xhc3MqPSdpdGVtLSddXCIpO1xuXG4gICAgZm9yIChjb25zdCBlbGVtZW50IG9mIHRhYnMpIHtcbiAgICAgIGVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcihcImNsaWNrXCIsICgpID0+IHtcbiAgICAgICAgdGhpcy5zZXRTdGF0ZSh7XG4gICAgICAgICAgc2VsZWN0ZWQ6IG51bGxcbiAgICAgICAgfSk7XG4gICAgICB9KTtcbiAgICB9XG5cbiAgICB0aGlzLnNldEluaXRpYWxTdGF0ZSgpO1xuICAgIHRoaXMub25DbGljayA9IHRoaXMub25DbGljay5iaW5kKHRoaXMpO1xuICAgIHRoaXMuc2V0U2VsZWN0ZWQgPSB0aGlzLnNldFNlbGVjdGVkLmJpbmQodGhpcyk7XG4gIH1cblxuICBzZXRJbml0aWFsU3RhdGUoKSB7XG4gICAgY29uc3Qgc2VsZiA9IHRoaXM7XG4gICAgc2VsZi5zdGF0ZSA9IHtcbiAgICAgIHNlbGVjdGVkOiBudWxsLFxuICAgICAgaXRlbXM6IHNlbGYucHJvcHMuaXRlbXNcbiAgICB9O1xuICAgIGNvbnN0IGluaXRpYWxTZWxlY3Rpb24gPSBzZWxmLnByb3BzLml0ZW1zLmZpbmQoaXRlbSA9PiB7XG4gICAgICByZXR1cm4gaXRlbS5zZWxlY3RlZDtcbiAgICB9KTtcblxuICAgIGlmIChpbml0aWFsU2VsZWN0aW9uKSB7XG4gICAgICBzZWxmLnN0YXRlLnNlbGVjdGVkID0gaW5pdGlhbFNlbGVjdGlvbi5pZDtcbiAgICB9XG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgY29uc3Qgc2VsZiA9IHRoaXM7XG4gICAgY29uc3Qge1xuICAgICAgaGVhZGVyVGV4dFxuICAgIH0gPSBzZWxmLnByb3BzO1xuICAgIGNvbnN0IHtcbiAgICAgIGl0ZW1zLFxuICAgICAgc2VsZWN0ZWRcbiAgICB9ID0gc2VsZi5zdGF0ZTtcbiAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIG51bGwsIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChUYWJCYXJTZXBhcmF0b3IsIG51bGwpLCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoVGFiQmFySGVhZGVyLCB7XG4gICAgICB0ZXh0OiBoZWFkZXJUZXh0LFxuICAgICAgYnV0dG9uOiB0aGlzLnByb3BzLmhlYWRlckJ1dHRvblxuICAgIH0pLCBpdGVtcy5tYXAoaXRlbSA9PiB7XG4gICAgICBjb25zdCB7XG4gICAgICAgIGlkLFxuICAgICAgICB0ZXh0XG4gICAgICB9ID0gaXRlbTtcbiAgICAgIHJldHVybiBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoVGFiQmFySXRlbSwge1xuICAgICAgICBrZXk6IGlkLFxuICAgICAgICBzZWxlY3RlZDogc2VsZWN0ZWQgPT09IGlkLFxuICAgICAgICB0ZXh0OiB0ZXh0LFxuICAgICAgICBpZDogaWQsXG4gICAgICAgIG9uQ2xpY2s6IHNlbGYub25DbGlja1xuICAgICAgfSk7XG4gICAgfSkpO1xuICB9XG5cbiAgc2V0U2VsZWN0ZWQoZSkge1xuICAgIGUudGFyZ2V0LmNsYXNzTmFtZSA9IHRoaXMuc2NuO1xuICB9XG5cbiAgb25DbGljayhpZCkge1xuICAgIGNvbnN0IHNpID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvcihcIltjbGFzcyo9c2lkZV0gPiBbY2xhc3MqPXNlbGVjdGVkXVwiKTtcblxuICAgIGlmIChzaSkge1xuICAgICAgc2kucmVtb3ZlRXZlbnRMaXN0ZW5lcihcImNsaWNrXCIsIHRoaXMuc2V0U2VsZWN0ZWQpO1xuICAgICAgc2kuYWRkRXZlbnRMaXN0ZW5lcihcImNsaWNrXCIsIHRoaXMuc2V0U2VsZWN0ZWQpO1xuICAgICAgc2kuY2xhc3NOYW1lID0gdGhpcy5uc2NuO1xuICAgIH1cblxuICAgIHRoaXMuc2V0U3RhdGUoe1xuICAgICAgc2VsZWN0ZWQ6IG51bGxcbiAgICB9KTtcbiAgICB0aGlzLnNldFN0YXRlKHtcbiAgICAgIHNlbGVjdGVkOiBpZFxuICAgIH0pO1xuICAgIGlmICh0aGlzLnByb3BzLm9uQ2xpY2spIHRoaXMucHJvcHMub25DbGljayhpZCk7XG4gIH1cblxufSJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/sidebar.js\n"); + +/***/ }), + +/***/ "./src/ui/switch.js": +/*!**************************!*\ + !*** ./src/ui/switch.js ***! + \**************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return SwitchItem; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _components_switch__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./components/switch */ \"./src/ui/components/switch.jsx\");\n\n\nclass SwitchItem extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n this.onChange = this.onChange.bind(this);\n }\n\n onChange() {\n this.props.checked = !this.props.checked;\n this.props.onChange(this.props.id, this.props.checked);\n }\n\n render() {\n const {\n text,\n info\n } = this.props.data;\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-flex flex-vertical flex-justify-start flex-align-stretch flex-nowrap ui-switch-item\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-flex flex-horizontal flex-justify-start flex-align-stretch flex-nowrap\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"h3\", {\n className: \"ui-form-title h3 margin-reset margin-reset ui-flex-child\"\n }, text), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_components_switch__WEBPACK_IMPORTED_MODULE_1__[\"default\"], {\n onChange: this.onChange,\n checked: this.props.checked\n })), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-form-text style-description margin-top-4\",\n style: {\n flex: \"1 1 auto\"\n }\n }, info));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvc3dpdGNoLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQmV0dGVyRGlzY29yZC8uL3NyYy91aS9zd2l0Y2guanM/YjA2YSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQkRWMiBmcm9tIFwiLi4vbW9kdWxlcy92MlwiO1xuaW1wb3J0IFN3aXRjaCBmcm9tIFwiLi9jb21wb25lbnRzL3N3aXRjaFwiO1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgU3dpdGNoSXRlbSBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgICB0aGlzLm9uQ2hhbmdlID0gdGhpcy5vbkNoYW5nZS5iaW5kKHRoaXMpO1xuICB9XG5cbiAgb25DaGFuZ2UoKSB7XG4gICAgdGhpcy5wcm9wcy5jaGVja2VkID0gIXRoaXMucHJvcHMuY2hlY2tlZDtcbiAgICB0aGlzLnByb3BzLm9uQ2hhbmdlKHRoaXMucHJvcHMuaWQsIHRoaXMucHJvcHMuY2hlY2tlZCk7XG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgY29uc3Qge1xuICAgICAgdGV4dCxcbiAgICAgIGluZm9cbiAgICB9ID0gdGhpcy5wcm9wcy5kYXRhO1xuICAgIHJldHVybiBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcInVpLWZsZXggZmxleC12ZXJ0aWNhbCBmbGV4LWp1c3RpZnktc3RhcnQgZmxleC1hbGlnbi1zdHJldGNoIGZsZXgtbm93cmFwIHVpLXN3aXRjaC1pdGVtXCJcbiAgICB9LCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcInVpLWZsZXggZmxleC1ob3Jpem9udGFsIGZsZXgtanVzdGlmeS1zdGFydCBmbGV4LWFsaWduLXN0cmV0Y2ggZmxleC1ub3dyYXBcIlxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImgzXCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJ1aS1mb3JtLXRpdGxlIGgzIG1hcmdpbi1yZXNldCBtYXJnaW4tcmVzZXQgdWktZmxleC1jaGlsZFwiXG4gICAgfSwgdGV4dCksIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChTd2l0Y2gsIHtcbiAgICAgIG9uQ2hhbmdlOiB0aGlzLm9uQ2hhbmdlLFxuICAgICAgY2hlY2tlZDogdGhpcy5wcm9wcy5jaGVja2VkXG4gICAgfSkpLCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcInVpLWZvcm0tdGV4dCBzdHlsZS1kZXNjcmlwdGlvbiBtYXJnaW4tdG9wLTRcIixcbiAgICAgIHN0eWxlOiB7XG4gICAgICAgIGZsZXg6IFwiMSAxIGF1dG9cIlxuICAgICAgfVxuICAgIH0sIGluZm8pKTtcbiAgfVxuXG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/switch.js\n"); + +/***/ }), + +/***/ "./src/ui/tabBarHeader.js": +/*!********************************!*\ + !*** ./src/ui/tabBarHeader.js ***! + \********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_TabBarHeader; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass V2C_TabBarHeader extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n }\n\n render() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-tab-bar-header\"\n }, this.props.text, this.props.button);\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvdGFiQmFySGVhZGVyLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQmV0dGVyRGlzY29yZC8uL3NyYy91aS90YWJCYXJIZWFkZXIuanM/MTM0ZiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQkRWMiBmcm9tIFwiLi4vbW9kdWxlcy92MlwiO1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgVjJDX1RhYkJhckhlYWRlciBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJ1aS10YWItYmFyLWhlYWRlclwiXG4gICAgfSwgdGhpcy5wcm9wcy50ZXh0LCB0aGlzLnByb3BzLmJ1dHRvbik7XG4gIH1cblxufSJdLCJtYXBwaW5ncyI6IkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/tabBarHeader.js\n"); + +/***/ }), + +/***/ "./src/ui/tabBarItem.js": +/*!******************************!*\ + !*** ./src/ui/tabBarItem.js ***! + \******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_TabBarItem; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass V2C_TabBarItem extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n this.setInitialState();\n this.onClick = this.onClick.bind(this);\n }\n\n setInitialState() {\n this.state = {\n selected: this.props.selected || false\n };\n }\n\n render() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: `ui-tab-bar-item${this.props.selected ? \" selected\" : \"\"}`,\n onClick: this.onClick\n }, this.props.text);\n }\n\n onClick() {\n if (this.props.onClick) {\n this.props.onClick(this.props.id);\n }\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvdGFiQmFySXRlbS5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkvdGFiQmFySXRlbS5qcz81YzZhIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi9tb2R1bGVzL3YyXCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWMkNfVGFiQmFySXRlbSBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgICB0aGlzLnNldEluaXRpYWxTdGF0ZSgpO1xuICAgIHRoaXMub25DbGljayA9IHRoaXMub25DbGljay5iaW5kKHRoaXMpO1xuICB9XG5cbiAgc2V0SW5pdGlhbFN0YXRlKCkge1xuICAgIHRoaXMuc3RhdGUgPSB7XG4gICAgICBzZWxlY3RlZDogdGhpcy5wcm9wcy5zZWxlY3RlZCB8fCBmYWxzZVxuICAgIH07XG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgcmV0dXJuIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IGB1aS10YWItYmFyLWl0ZW0ke3RoaXMucHJvcHMuc2VsZWN0ZWQgPyBcIiBzZWxlY3RlZFwiIDogXCJcIn1gLFxuICAgICAgb25DbGljazogdGhpcy5vbkNsaWNrXG4gICAgfSwgdGhpcy5wcm9wcy50ZXh0KTtcbiAgfVxuXG4gIG9uQ2xpY2soKSB7XG4gICAgaWYgKHRoaXMucHJvcHMub25DbGljaykge1xuICAgICAgdGhpcy5wcm9wcy5vbkNsaWNrKHRoaXMucHJvcHMuaWQpO1xuICAgIH1cbiAgfVxuXG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/tabBarItem.js\n"); + +/***/ }), + +/***/ "./src/ui/tabBarSeparator.js": +/*!***********************************!*\ + !*** ./src/ui/tabBarSeparator.js ***! + \***********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_TabBarSeparator; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass V2C_TabBarSeparator extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n }\n\n render() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"ui-tab-bar-separator margin-top-8 margin-bottom-8\"\n });\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvdGFiQmFyU2VwYXJhdG9yLmpzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQmV0dGVyRGlzY29yZC8uL3NyYy91aS90YWJCYXJTZXBhcmF0b3IuanM/MzI0MiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQkRWMiBmcm9tIFwiLi4vbW9kdWxlcy92MlwiO1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgVjJDX1RhYkJhclNlcGFyYXRvciBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJ1aS10YWItYmFyLXNlcGFyYXRvciBtYXJnaW4tdG9wLTggbWFyZ2luLWJvdHRvbS04XCJcbiAgICB9KTtcbiAgfVxuXG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/tabBarSeparator.js\n"); + +/***/ }), + +/***/ "./src/ui/tools.js": +/*!*************************!*\ + !*** ./src/ui/tools.js ***! + \*************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_Tools; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _xSvg__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./xSvg */ \"./src/ui/xSvg.js\");\n\n\nclass V2C_Tools extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n this.onClick = this.onClick.bind(this);\n }\n\n render() {\n let toolsModule = BDModules.get(e => e.toolsContainer)[0];\n let containerModule = BDModules.get(e => e.container && e.closeButton && e.closeButtonBold)[0];\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"tools-container \" + toolsModule.toolsContainer\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"tools \" + toolsModule.tools\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: containerModule.container\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"btn-close \" + containerModule.closeButton,\n onClick: this.onClick\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(_xSvg__WEBPACK_IMPORTED_MODULE_1__[\"default\"], null)), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"div\", {\n className: \"esc-text \" + containerModule.keybind\n }, \"ESC\"))));\n }\n\n onClick() {\n if (this.props.onClick) {\n this.props.onClick();\n }\n\n const closeButton = document.querySelector(\".\" + BDModules.get(e => e.closeButton && e.keybindBold)[0].closeButton.split(\" \")[0]);\n if (closeButton) closeButton.click();\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvdG9vbHMuanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL3VpL3Rvb2xzLmpzPzA3ZWQiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJEVjIgZnJvbSBcIi4uL21vZHVsZXMvdjJcIjtcbmltcG9ydCBYU3ZnIGZyb20gXCIuL3hTdmdcIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFYyQ19Ub29scyBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgICB0aGlzLm9uQ2xpY2sgPSB0aGlzLm9uQ2xpY2suYmluZCh0aGlzKTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBsZXQgdG9vbHNNb2R1bGUgPSBCRE1vZHVsZXMuZ2V0KGUgPT4gZS50b29sc0NvbnRhaW5lcilbMF07XG4gICAgbGV0IGNvbnRhaW5lck1vZHVsZSA9IEJETW9kdWxlcy5nZXQoZSA9PiBlLmNvbnRhaW5lciAmJiBlLmNsb3NlQnV0dG9uICYmIGUuY2xvc2VCdXR0b25Cb2xkKVswXTtcbiAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJ0b29scy1jb250YWluZXIgXCIgKyB0b29sc01vZHVsZS50b29sc0NvbnRhaW5lclxuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IFwidG9vbHMgXCIgKyB0b29sc01vZHVsZS50b29sc1xuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IGNvbnRhaW5lck1vZHVsZS5jb250YWluZXJcbiAgICB9LCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcImJ0bi1jbG9zZSBcIiArIGNvbnRhaW5lck1vZHVsZS5jbG9zZUJ1dHRvbixcbiAgICAgIG9uQ2xpY2s6IHRoaXMub25DbGlja1xuICAgIH0sIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChYU3ZnLCBudWxsKSksIEJEVjIucmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgICBjbGFzc05hbWU6IFwiZXNjLXRleHQgXCIgKyBjb250YWluZXJNb2R1bGUua2V5YmluZFxuICAgIH0sIFwiRVNDXCIpKSkpO1xuICB9XG5cbiAgb25DbGljaygpIHtcbiAgICBpZiAodGhpcy5wcm9wcy5vbkNsaWNrKSB7XG4gICAgICB0aGlzLnByb3BzLm9uQ2xpY2soKTtcbiAgICB9XG5cbiAgICBjb25zdCBjbG9zZUJ1dHRvbiA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoXCIuXCIgKyBCRE1vZHVsZXMuZ2V0KGUgPT4gZS5jbG9zZUJ1dHRvbiAmJiBlLmtleWJpbmRCb2xkKVswXS5jbG9zZUJ1dHRvbi5zcGxpdChcIiBcIilbMF0pO1xuICAgIGlmIChjbG9zZUJ1dHRvbikgY2xvc2VCdXR0b24uY2xpY2soKTtcbiAgfVxuXG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/tools.js\n"); + +/***/ }), + +/***/ "./src/ui/tooltip.js": +/*!***************************!*\ + !*** ./src/ui/tooltip.js ***! + \***************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return EmulatedTooltip; });\n/* harmony import */ var _modules_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/utils */ \"./src/modules/utils.js\");\n/* harmony import */ var _modules_webpackModules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../modules/webpackModules */ \"./src/modules/webpackModules.js\");\n/**\r\n * Tooltip that automatically show and hide themselves on mouseenter and mouseleave events.\r\n * Will also remove themselves if the node to watch is removed from DOM through\r\n * a MutationObserver.\r\n *\r\n * Note this is not using Discord's internals but normal DOM manipulation and emulates\r\n * Discord's own tooltips as closely as possible.\r\n *\r\n * @module EmulatedTooltip\r\n * @version 0.0.1\r\n */\n\n\nconst TooltipClasses = _modules_webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].findByProps(\"tooltip\", \"tooltipBlack\");\nconst TooltipLayers = _modules_webpackModules__WEBPACK_IMPORTED_MODULE_1__[\"default\"].findByProps(\"layer\", \"layerContainer\");\n\nconst getClass = function (sideOrColor) {\n const upperCase = sideOrColor[0].toUpperCase() + sideOrColor.slice(1);\n const tooltipClass = TooltipClasses[`tooltip${upperCase}`];\n if (tooltipClass) return tooltipClass;\n return null;\n};\n\nconst classExists = function (sideOrColor) {\n return getClass(sideOrColor) ? true : false;\n};\n\nconst toPx = function (value) {\n return `${value}px`;\n};\n/*
\r\n
\r\n
\r\n User Settings\r\n
\r\n
*/\n\n\nclass EmulatedTooltip {\n /**\r\n *\r\n * @constructor\r\n * @param {(HTMLElement|jQuery)} node - DOM node to monitor and show the tooltip on\r\n * @param {string} tip - string to show in the tooltip\r\n * @param {object} options - additional options for the tooltip\r\n * @param {string} [options.style=black] - correlates to the discord styling/colors (black, brand, green, grey, red, yellow)\r\n * @param {string} [options.side=top] - can be any of top, right, bottom, left\r\n * @param {boolean} [options.preventFlip=false] - prevents moving the tooltip to the opposite side if it is too big or goes offscreen\r\n * @param {boolean} [options.disabled=false] - whether the tooltip should be disabled from showing on hover\r\n */\n constructor(node, text, options = {}) {\n const {\n style = \"black\",\n side = \"top\",\n preventFlip = false,\n disabled = false\n } = options;\n this.node = node instanceof jQuery ? node[0] : node;\n this.label = text;\n this.style = style.toLowerCase();\n this.side = side.toLowerCase();\n this.preventFlip = preventFlip;\n this.disabled = disabled;\n if (!classExists(this.side)) return _modules_utils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].err(\"EmulatedTooltip\", `Side ${this.side} does not exist.`);\n if (!classExists(this.style)) return _modules_utils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].err(\"EmulatedTooltip\", `Style ${this.style} does not exist.`);\n this.element = document.createElement(\"div\");\n this.element.className = TooltipLayers.layer + \" \" + TooltipLayers.disabledPointerEvents;\n this.tooltipElement = document.createElement(\"div\");\n this.tooltipElement.className = `${TooltipClasses.tooltip} ${getClass(this.style)}`;\n this.labelElement = document.createElement(\"div\");\n this.labelElement.className = TooltipClasses.tooltipContent;\n const pointerElement = document.createElement(\"div\");\n pointerElement.className = TooltipClasses.tooltipPointer;\n this.tooltipElement.append(pointerElement);\n this.tooltipElement.append(this.labelElement);\n this.element.append(this.tooltipElement);\n this.node.addEventListener(\"mouseenter\", () => {\n if (this.disabled) return;\n this.show();\n const observer = new MutationObserver(mutations => {\n mutations.forEach(mutation => {\n const nodes = Array.from(mutation.removedNodes);\n const directMatch = nodes.indexOf(this.node) > -1;\n const parentMatch = nodes.some(parent => parent.contains(this.node));\n\n if (directMatch || parentMatch) {\n this.hide();\n observer.disconnect();\n }\n });\n });\n observer.observe(document.body, {\n subtree: true,\n childList: true\n });\n });\n this.node.addEventListener(\"mouseleave\", () => {\n this.hide();\n });\n }\n /** Container where the tooltip will be appended. */\n\n\n get container() {\n return document.querySelector(\".\" + BDModules.get(e => e.popouts)[0].popouts.split(\" \")[0] + \" ~ .\" + BDModules.get(e => e.layerContainer)[0].layerContainer.split(\" \")[0]);\n }\n /** Boolean representing if the tooltip will fit on screen above the element */\n\n\n get canShowAbove() {\n return this.node.getBoundingClientRect().top - this.element.offsetHeight >= 0;\n }\n /** Boolean representing if the tooltip will fit on screen below the element */\n\n\n get canShowBelow() {\n return this.node.getBoundingClientRect().top + this.node.offsetHeight + this.element.offsetHeight <= _modules_utils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].screenHeight;\n }\n /** Boolean representing if the tooltip will fit on screen to the left of the element */\n\n\n get canShowLeft() {\n return this.node.getBoundingClientRect().left - this.element.offsetWidth >= 0;\n }\n /** Boolean representing if the tooltip will fit on screen to the right of the element */\n\n\n get canShowRight() {\n return this.node.getBoundingClientRect().left + this.node.offsetWidth + this.element.offsetWidth <= _modules_utils__WEBPACK_IMPORTED_MODULE_0__[\"default\"].screenWidth;\n }\n /** Hides the tooltip. Automatically called on mouseleave. */\n\n\n hide() {\n this.element.remove();\n this.tooltipElement.className = this._className;\n }\n /** Shows the tooltip. Automatically called on mouseenter. Will attempt to flip if position was wrong. */\n\n\n show() {\n this.tooltipElement.className = `${TooltipClasses.tooltip} ${getClass(this.style)}`;\n this.labelElement.textContent = this.label;\n this.container.append(this.element);\n\n if (this.side == \"top\") {\n if (this.canShowAbove || !this.canShowAbove && this.preventFlip) this.showAbove();else this.showBelow();\n }\n\n if (this.side == \"bottom\") {\n if (this.canShowBelow || !this.canShowBelow && this.preventFlip) this.showBelow();else this.showAbove();\n }\n\n if (this.side == \"left\") {\n if (this.canShowLeft || !this.canShowLeft && this.preventFlip) this.showLeft();else this.showRight();\n }\n\n if (this.side == \"right\") {\n if (this.canShowRight || !this.canShowRight && this.preventFlip) this.showRight();else this.showLeft();\n }\n }\n /** Force showing the tooltip above the node. */\n\n\n showAbove() {\n this.tooltipElement.classList.add(getClass(\"top\"));\n this.element.style.setProperty(\"top\", toPx(this.node.getBoundingClientRect().top - this.element.offsetHeight - 10));\n this.centerHorizontally();\n }\n /** Force showing the tooltip below the node. */\n\n\n showBelow() {\n this.tooltipElement.classList.add(getClass(\"bottom\"));\n this.element.style.setProperty(\"top\", toPx(this.node.getBoundingClientRect().top + this.node.offsetHeight + 10));\n this.centerHorizontally();\n }\n /** Force showing the tooltip to the left of the node. */\n\n\n showLeft() {\n this.tooltipElement.classList.add(getClass(\"left\"));\n this.element.style.setProperty(\"left\", toPx(this.node.getBoundingClientRect().left - this.element.offsetWidth - 10));\n this.centerVertically();\n }\n /** Force showing the tooltip to the right of the node. */\n\n\n showRight() {\n this.tooltipElement.classList.add(getClass(\"right\"));\n this.element.style.setProperty(\"left\", toPx(this.node.getBoundingClientRect().left + this.node.offsetWidth + 10));\n this.centerVertically();\n }\n\n centerHorizontally() {\n const nodecenter = this.node.getBoundingClientRect().left + this.node.offsetWidth / 2;\n this.element.style.setProperty(\"left\", toPx(nodecenter - this.element.offsetWidth / 2));\n }\n\n centerVertically() {\n const nodecenter = this.node.getBoundingClientRect().top + this.node.offsetHeight / 2;\n this.element.style.setProperty(\"top\", toPx(nodecenter - this.element.offsetHeight / 2));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/ui/tooltip.js.js","sources":["webpack://BetterDiscord/./src/ui/tooltip.js?949e"],"sourcesContent":["/**\r\n * Tooltip that automatically show and hide themselves on mouseenter and mouseleave events.\r\n * Will also remove themselves if the node to watch is removed from DOM through\r\n * a MutationObserver.\r\n *\r\n * Note this is not using Discord's internals but normal DOM manipulation and emulates\r\n * Discord's own tooltips as closely as possible.\r\n *\r\n * @module EmulatedTooltip\r\n * @version 0.0.1\r\n */\nimport Utils from \"../modules/utils\";\nimport WebpackModules from \"../modules/webpackModules\";\nconst TooltipClasses = WebpackModules.findByProps(\"tooltip\", \"tooltipBlack\");\nconst TooltipLayers = WebpackModules.findByProps(\"layer\", \"layerContainer\");\n\nconst getClass = function (sideOrColor) {\n  const upperCase = sideOrColor[0].toUpperCase() + sideOrColor.slice(1);\n  const tooltipClass = TooltipClasses[`tooltip${upperCase}`];\n  if (tooltipClass) return tooltipClass;\n  return null;\n};\n\nconst classExists = function (sideOrColor) {\n  return getClass(sideOrColor) ? true : false;\n};\n\nconst toPx = function (value) {\n  return `${value}px`;\n};\n/* <div class=\"layer-v9HyYc da-layer\" style=\"left: 234.5px; bottom: 51px;\">\r\n    <div class=\"tooltip-2QfLtc da-tooltip tooltipTop-XDDSxx tooltipBlack-PPG47z\">\r\n        <div class=\"tooltipPointer-3ZfirK da-tooltipPointer\"></div>\r\n        User Settings\r\n    </div>\r\n</div> */\n\n\nexport default class EmulatedTooltip {\n  /**\r\n   *\r\n   * @constructor\r\n   * @param {(HTMLElement|jQuery)} node - DOM node to monitor and show the tooltip on\r\n   * @param {string} tip - string to show in the tooltip\r\n   * @param {object} options - additional options for the tooltip\r\n   * @param {string} [options.style=black] - correlates to the discord styling/colors (black, brand, green, grey, red, yellow)\r\n   * @param {string} [options.side=top] - can be any of top, right, bottom, left\r\n   * @param {boolean} [options.preventFlip=false] - prevents moving the tooltip to the opposite side if it is too big or goes offscreen\r\n      * @param {boolean} [options.disabled=false] - whether the tooltip should be disabled from showing on hover\r\n   */\n  constructor(node, text, options = {}) {\n    const {\n      style = \"black\",\n      side = \"top\",\n      preventFlip = false,\n      disabled = false\n    } = options;\n    this.node = node instanceof jQuery ? node[0] : node;\n    this.label = text;\n    this.style = style.toLowerCase();\n    this.side = side.toLowerCase();\n    this.preventFlip = preventFlip;\n    this.disabled = disabled;\n    if (!classExists(this.side)) return Utils.err(\"EmulatedTooltip\", `Side ${this.side} does not exist.`);\n    if (!classExists(this.style)) return Utils.err(\"EmulatedTooltip\", `Style ${this.style} does not exist.`);\n    this.element = document.createElement(\"div\");\n    this.element.className = TooltipLayers.layer + \" \" + TooltipLayers.disabledPointerEvents;\n    this.tooltipElement = document.createElement(\"div\");\n    this.tooltipElement.className = `${TooltipClasses.tooltip} ${getClass(this.style)}`;\n    this.labelElement = document.createElement(\"div\");\n    this.labelElement.className = TooltipClasses.tooltipContent;\n    const pointerElement = document.createElement(\"div\");\n    pointerElement.className = TooltipClasses.tooltipPointer;\n    this.tooltipElement.append(pointerElement);\n    this.tooltipElement.append(this.labelElement);\n    this.element.append(this.tooltipElement);\n    this.node.addEventListener(\"mouseenter\", () => {\n      if (this.disabled) return;\n      this.show();\n      const observer = new MutationObserver(mutations => {\n        mutations.forEach(mutation => {\n          const nodes = Array.from(mutation.removedNodes);\n          const directMatch = nodes.indexOf(this.node) > -1;\n          const parentMatch = nodes.some(parent => parent.contains(this.node));\n\n          if (directMatch || parentMatch) {\n            this.hide();\n            observer.disconnect();\n          }\n        });\n      });\n      observer.observe(document.body, {\n        subtree: true,\n        childList: true\n      });\n    });\n    this.node.addEventListener(\"mouseleave\", () => {\n      this.hide();\n    });\n  }\n  /** Container where the tooltip will be appended. */\n\n\n  get container() {\n    return document.querySelector(\".\" + BDModules.get(e => e.popouts)[0].popouts.split(\" \")[0] + \" ~ .\" + BDModules.get(e => e.layerContainer)[0].layerContainer.split(\" \")[0]);\n  }\n  /** Boolean representing if the tooltip will fit on screen above the element */\n\n\n  get canShowAbove() {\n    return this.node.getBoundingClientRect().top - this.element.offsetHeight >= 0;\n  }\n  /** Boolean representing if the tooltip will fit on screen below the element */\n\n\n  get canShowBelow() {\n    return this.node.getBoundingClientRect().top + this.node.offsetHeight + this.element.offsetHeight <= Utils.screenHeight;\n  }\n  /** Boolean representing if the tooltip will fit on screen to the left of the element */\n\n\n  get canShowLeft() {\n    return this.node.getBoundingClientRect().left - this.element.offsetWidth >= 0;\n  }\n  /** Boolean representing if the tooltip will fit on screen to the right of the element */\n\n\n  get canShowRight() {\n    return this.node.getBoundingClientRect().left + this.node.offsetWidth + this.element.offsetWidth <= Utils.screenWidth;\n  }\n  /** Hides the tooltip. Automatically called on mouseleave. */\n\n\n  hide() {\n    this.element.remove();\n    this.tooltipElement.className = this._className;\n  }\n  /** Shows the tooltip. Automatically called on mouseenter. Will attempt to flip if position was wrong. */\n\n\n  show() {\n    this.tooltipElement.className = `${TooltipClasses.tooltip} ${getClass(this.style)}`;\n    this.labelElement.textContent = this.label;\n    this.container.append(this.element);\n\n    if (this.side == \"top\") {\n      if (this.canShowAbove || !this.canShowAbove && this.preventFlip) this.showAbove();else this.showBelow();\n    }\n\n    if (this.side == \"bottom\") {\n      if (this.canShowBelow || !this.canShowBelow && this.preventFlip) this.showBelow();else this.showAbove();\n    }\n\n    if (this.side == \"left\") {\n      if (this.canShowLeft || !this.canShowLeft && this.preventFlip) this.showLeft();else this.showRight();\n    }\n\n    if (this.side == \"right\") {\n      if (this.canShowRight || !this.canShowRight && this.preventFlip) this.showRight();else this.showLeft();\n    }\n  }\n  /** Force showing the tooltip above the node. */\n\n\n  showAbove() {\n    this.tooltipElement.classList.add(getClass(\"top\"));\n    this.element.style.setProperty(\"top\", toPx(this.node.getBoundingClientRect().top - this.element.offsetHeight - 10));\n    this.centerHorizontally();\n  }\n  /** Force showing the tooltip below the node. */\n\n\n  showBelow() {\n    this.tooltipElement.classList.add(getClass(\"bottom\"));\n    this.element.style.setProperty(\"top\", toPx(this.node.getBoundingClientRect().top + this.node.offsetHeight + 10));\n    this.centerHorizontally();\n  }\n  /** Force showing the tooltip to the left of the node. */\n\n\n  showLeft() {\n    this.tooltipElement.classList.add(getClass(\"left\"));\n    this.element.style.setProperty(\"left\", toPx(this.node.getBoundingClientRect().left - this.element.offsetWidth - 10));\n    this.centerVertically();\n  }\n  /** Force showing the tooltip to the right of the node. */\n\n\n  showRight() {\n    this.tooltipElement.classList.add(getClass(\"right\"));\n    this.element.style.setProperty(\"left\", toPx(this.node.getBoundingClientRect().left + this.node.offsetWidth + 10));\n    this.centerVertically();\n  }\n\n  centerHorizontally() {\n    const nodecenter = this.node.getBoundingClientRect().left + this.node.offsetWidth / 2;\n    this.element.style.setProperty(\"left\", toPx(nodecenter - this.element.offsetWidth / 2));\n  }\n\n  centerVertically() {\n    const nodecenter = this.node.getBoundingClientRect().top + this.node.offsetHeight / 2;\n    this.element.style.setProperty(\"top\", toPx(nodecenter - this.element.offsetHeight / 2));\n  }\n\n}"],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/ui/tooltip.js\n"); + +/***/ }), + +/***/ "./src/ui/tooltipWrap.js": +/*!*******************************!*\ + !*** ./src/ui/tooltipWrap.js ***! + \*******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n/* harmony import */ var _tooltip__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./tooltip */ \"./src/ui/tooltip.js\");\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (class extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n }\n\n async componentDidMount() {\n const {\n style = \"black\",\n side = \"top\",\n text = \"\"\n } = this.props;\n this.node = _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactDom.findDOMNode(this);\n this.tooltip = new _tooltip__WEBPACK_IMPORTED_MODULE_1__[\"default\"](this.node, text, {\n style,\n side\n });\n }\n\n componentWillUnmount() {\n this.tooltip.hide();\n delete this.tooltip;\n }\n\n render() {\n return this.props.children;\n }\n\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvdG9vbHRpcFdyYXAuanMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9CZXR0ZXJEaXNjb3JkLy4vc3JjL3VpL3Rvb2x0aXBXcmFwLmpzPzk5ZTEiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJEVjIgZnJvbSBcIi4uL21vZHVsZXMvdjJcIjtcbmltcG9ydCBUb29sdGlwIGZyb20gXCIuL3Rvb2x0aXBcIjtcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIGV4dGVuZHMgQkRWMi5yZWFjdENvbXBvbmVudCB7XG4gIGNvbnN0cnVjdG9yKHByb3BzKSB7XG4gICAgc3VwZXIocHJvcHMpO1xuICB9XG5cbiAgYXN5bmMgY29tcG9uZW50RGlkTW91bnQoKSB7XG4gICAgY29uc3Qge1xuICAgICAgc3R5bGUgPSBcImJsYWNrXCIsXG4gICAgICBzaWRlID0gXCJ0b3BcIixcbiAgICAgIHRleHQgPSBcIlwiXG4gICAgfSA9IHRoaXMucHJvcHM7XG4gICAgdGhpcy5ub2RlID0gQkRWMi5yZWFjdERvbS5maW5kRE9NTm9kZSh0aGlzKTtcbiAgICB0aGlzLnRvb2x0aXAgPSBuZXcgVG9vbHRpcCh0aGlzLm5vZGUsIHRleHQsIHtcbiAgICAgIHN0eWxlLFxuICAgICAgc2lkZVxuICAgIH0pO1xuICB9XG5cbiAgY29tcG9uZW50V2lsbFVubW91bnQoKSB7XG4gICAgdGhpcy50b29sdGlwLmhpZGUoKTtcbiAgICBkZWxldGUgdGhpcy50b29sdGlwO1xuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIHJldHVybiB0aGlzLnByb3BzLmNoaWxkcmVuO1xuICB9XG5cbn0iXSwibWFwcGluZ3MiOiJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/tooltipWrap.js\n"); + +/***/ }), + +/***/ "./src/ui/xSvg.js": +/*!************************!*\ + !*** ./src/ui/xSvg.js ***! + \************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return V2C_XSvg; });\n/* harmony import */ var _modules_v2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../modules/v2 */ \"./src/modules/v2.js\");\n\nclass V2C_XSvg extends _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].reactComponent {\n constructor(props) {\n super(props);\n }\n\n render() {\n return _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"svg\", {\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 12 12\",\n style: {\n width: \"18px\",\n height: \"18px\"\n }\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"g\", {\n className: \"background\",\n fill: \"none\",\n fillRule: \"evenodd\"\n }, _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"path\", {\n d: \"M0 0h12v12H0\"\n }), _modules_v2__WEBPACK_IMPORTED_MODULE_0__[\"default\"].react.createElement(\"path\", {\n className: \"fill\",\n fill: \"#dcddde\",\n d: \"M9.5 3.205L8.795 2.5 6 5.295 3.205 2.5l-.705.705L5.295 6 2.5 8.795l.705.705L6 6.705 8.795 9.5l.705-.705L6.705 6\"\n })));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkveFN2Zy5qcy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovL0JldHRlckRpc2NvcmQvLi9zcmMvdWkveFN2Zy5qcz84MDhjIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCRFYyIGZyb20gXCIuLi9tb2R1bGVzL3YyXCI7XG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWMkNfWFN2ZyBleHRlbmRzIEJEVjIucmVhY3RDb21wb25lbnQge1xuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICByZXR1cm4gQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwic3ZnXCIsIHtcbiAgICAgIHhtbG5zOiBcImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIsXG4gICAgICB2aWV3Qm94OiBcIjAgMCAxMiAxMlwiLFxuICAgICAgc3R5bGU6IHtcbiAgICAgICAgd2lkdGg6IFwiMThweFwiLFxuICAgICAgICBoZWlnaHQ6IFwiMThweFwiXG4gICAgICB9XG4gICAgfSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwiZ1wiLCB7XG4gICAgICBjbGFzc05hbWU6IFwiYmFja2dyb3VuZFwiLFxuICAgICAgZmlsbDogXCJub25lXCIsXG4gICAgICBmaWxsUnVsZTogXCJldmVub2RkXCJcbiAgICB9LCBCRFYyLnJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJwYXRoXCIsIHtcbiAgICAgIGQ6IFwiTTAgMGgxMnYxMkgwXCJcbiAgICB9KSwgQkRWMi5yZWFjdC5jcmVhdGVFbGVtZW50KFwicGF0aFwiLCB7XG4gICAgICBjbGFzc05hbWU6IFwiZmlsbFwiLFxuICAgICAgZmlsbDogXCIjZGNkZGRlXCIsXG4gICAgICBkOiBcIk05LjUgMy4yMDVMOC43OTUgMi41IDYgNS4yOTUgMy4yMDUgMi41bC0uNzA1LjcwNUw1LjI5NSA2IDIuNSA4Ljc5NWwuNzA1LjcwNUw2IDYuNzA1IDguNzk1IDkuNWwuNzA1LS43MDVMNi43MDUgNlwiXG4gICAgfSkpKTtcbiAgfVxuXG59Il0sIm1hcHBpbmdzIjoiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/ui/xSvg.js\n"); + +/***/ }), + +/***/ "electron": +/*!***************************!*\ + !*** external "electron" ***! + \***************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +module.exports = require("electron"); + +/***/ }), + +/***/ "events": +/*!*************************!*\ + !*** external "events" ***! + \*************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +module.exports = require("events"); + +/***/ }), + +/***/ "fs": +/*!*********************!*\ + !*** external "fs" ***! + \*********************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +module.exports = require("fs"); + +/***/ }), + +/***/ "mkdirp": +/*!*************************!*\ + !*** external "mkdirp" ***! + \*************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +module.exports = require("mkdirp"); + +/***/ }), + +/***/ "module": +/*!*************************!*\ + !*** external "module" ***! + \*************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +module.exports = require("module"); + +/***/ }), + +/***/ "path": +/*!***********************!*\ + !*** external "path" ***! + \***********************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +module.exports = require("path"); + +/***/ }), + +/***/ "request": +/*!**************************!*\ + !*** external "request" ***! + \**************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +module.exports = require("request"); + +/***/ }), + +/***/ "rimraf": +/*!*************************!*\ + !*** external "rimraf" ***! + \*************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +module.exports = require("rimraf"); + +/***/ }), + +/***/ "yauzl": +/*!************************!*\ + !*** external "yauzl" ***! + \************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +module.exports = require("yauzl"); + +/***/ }) + +/******/ }); \ No newline at end of file diff --git a/BetterDiscordApp/js/main.min.js b/BetterDiscordApp/js/main.min.js new file mode 100644 index 0000000..91457f5 --- /dev/null +++ b/BetterDiscordApp/js/main.min.js @@ -0,0 +1 @@ +var Core=function(e){var t={};function n(s){if(t[s])return t[s].exports;var o=t[s]={i:s,l:!1,exports:{}};return e[s].call(o.exports,o,o.exports,n),o.l=!0,o.exports}return n.m=e,n.c=t,n.d=function(e,t,s){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:s})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var s=Object.create(null);if(n.r(s),Object.defineProperty(s,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var o in e)n.d(s,o,function(t){return e[t]}.bind(null,o));return s},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=9)}([function(e,t){e.exports=require("electron")},function(e,t){e.exports=require("path")},function(e,t){e.exports=require("fs")},function(e,t){e.exports=require("request")},function(e,t){e.exports=require("events")},function(e,t){e.exports=require("module")},function(e,t){e.exports=require("rimraf")},function(e,t){e.exports=require("yauzl")},function(e,t){e.exports=require("mkdirp")},function(e,t,n){"use strict";n.r(t);var s={};n.r(s),n.d(s,"minimumDiscordVersion",(function(){return o})),n.d(s,"currentDiscordVersion",(function(){return r})),n.d(s,"minSupportedVersion",(function(){return i})),n.d(s,"bbdVersion",(function(){return a})),n.d(s,"bbdChangelog",(function(){return l})),n.d(s,"settings",(function(){return c})),n.d(s,"defaultCookie",(function(){return d})),n.d(s,"settingsCookie",(function(){return u})),n.d(s,"bdpluginErrors",(function(){return h})),n.d(s,"bdthemeErrors",(function(){return p})),n.d(s,"bdConfig",(function(){return m})),n.d(s,"bemotes",(function(){return g})),n.d(s,"emotesFfz",(function(){return f})),n.d(s,"emotesBTTV",(function(){return b})),n.d(s,"emotesBTTV2",(function(){return y})),n.d(s,"emotesTwitch",(function(){return v})),n.d(s,"subEmotesTwitch",(function(){return C})),n.d(s,"bdEmotes",(function(){return w})),n.d(s,"bdEmoteSettingIDs",(function(){return E})),n.d(s,"bdthemes",(function(){return k})),n.d(s,"bdplugins",(function(){return S})),n.d(s,"pluginCookie",(function(){return x})),n.d(s,"themeCookie",(function(){return D}));const o="0.0.306",r=window.DiscordNative&&window.DiscordNative.remoteApp&&window.DiscordNative.remoteApp.getVersion&&window.DiscordNative.remoteApp.getVersion()||"0.0.306",i="0.3.0",a="0.3.4",l={description:"Big things are coming.",changes:[{title:"What's New?",items:["**In-App Updater** for the injection module now exists to try and decrease the number of issues with updates to the injector.","**Window Transparency** changes were made to more compatible with external window managers and addons like Glasscord.","Initialization sequence has once again been changed slightly to hopefully improve loading times."]},{title:"Bug Fixes",type:"fixed",items:["Some fixes related to showing modals in the `BdApi`."]}]},c={"Custom css live update":{id:"bda-css-0",info:"",implemented:!0,hidden:!0,cat:"core"},"Custom css auto udpate":{id:"bda-css-1",info:"",implemented:!0,hidden:!0,cat:"core"},"BetterDiscord Blue":{id:"bda-gs-b",info:"Replace Discord blue with BD Blue",implemented:!1,hidden:!1,cat:"core"},"Public Servers":{id:"bda-gs-1",info:"Display public servers button",implemented:!0,hidden:!1,cat:"core",category:"modules"},"Minimal Mode":{id:"bda-gs-2",info:"Hide elements and reduce the size of elements.",implemented:!0,hidden:!1,cat:"core",category:"modules"},"Voice Mode":{id:"bda-gs-4",info:"Only show voice chat",implemented:!0,hidden:!1,cat:"core",category:"modules"},"Hide Channels":{id:"bda-gs-3",info:"Hide channels in minimal mode",implemented:!0,hidden:!1,cat:"core",category:"modules"},"Dark Mode":{id:"bda-gs-5",info:"Make certain elements dark by default(wip)",implemented:!0,hidden:!1,cat:"core",category:"modules"},"Voice Disconnect":{id:"bda-dc-0",info:"Disconnect from voice server when closing Discord",implemented:!0,hidden:!1,cat:"core",category:"modules"},"24 Hour Timestamps":{id:"bda-gs-6",info:"Replace 12hr timestamps with proper ones",implemented:!0,hidden:!1,cat:"core",category:"modules"},"Colored Text":{id:"bda-gs-7",info:"Make text color the same as role color",implemented:!0,hidden:!1,cat:"core",category:"modules"},"Normalize Classes":{id:"fork-ps-4",info:"Adds stable classes to elements to help themes. (e.g. adds .da-channels to .channels-Ie2l6A)",implemented:!0,hidden:!1,cat:"core",category:"modules"},"Content Error Modal":{id:"fork-ps-1",info:"Shows a modal with plugin/theme errors",implemented:!0,hidden:!1,cat:"core",category:"content manager"},"Show Toasts":{id:"fork-ps-2",info:"Shows a small notification for important information",implemented:!0,hidden:!1,cat:"core",category:"content manager"},"Scroll To Settings":{id:"fork-ps-3",info:"Auto-scrolls to a plugin's settings when the button is clicked (only if out of view)",implemented:!0,hidden:!1,cat:"core",category:"content manager"},"Automatic Loading":{id:"fork-ps-5",info:"Automatically loads, reloads, and unloads plugins and themes",implemented:!0,hidden:!1,cat:"core",category:"content manager"},"Developer Mode":{id:"bda-gs-8",info:"Developer Mode",implemented:!0,hidden:!1,cat:"core",category:"developer settings"},"Copy Selector":{id:"fork-dm-1",info:'Adds a "Copy Selector" option to context menus when developer mode is active',implemented:!0,hidden:!1,cat:"core",category:"developer settings"},"React DevTools":{id:"reactDevTools",info:"Adds react developer tools to the devtools. Must be installed in Google Chrome on your pc.",implemented:!0,hidden:!0,cat:"core",category:"developer settings"},"Enable Transparency":{id:"fork-wp-1",info:"Enables the main window to be see-through (requires restart)",implemented:!0,hidden:!1,cat:"core",category:"window preferences"},"Window Frame":{id:"fork-wp-2",info:"Adds the native os window frame to the main window",implemented:!1,hidden:!0,cat:"core",category:"window preferences"},"Download Emotes":{id:"fork-es-3",info:"Download emotes when the cache is expired",implemented:!0,hidden:!1,cat:"emote"},"Twitch Emotes":{id:"bda-es-7",info:"Show Twitch emotes",implemented:!0,hidden:!1,cat:"emote"},"FrankerFaceZ Emotes":{id:"bda-es-1",info:"Show FrankerFaceZ Emotes",implemented:!0,hidden:!1,cat:"emote"},"BetterTTV Emotes":{id:"bda-es-2",info:"Show BetterTTV Emotes",implemented:!0,hidden:!1,cat:"emote"},"Emote Menu":{id:"bda-es-0",info:"Show Twitch/Favourite emotes in emote menu",implemented:!0,hidden:!1,cat:"emote"},"Emoji Menu":{id:"bda-es-9",info:"Show Discord emoji menu",implemented:!0,hidden:!1,cat:"emote"},"Emote Auto Capitalization":{id:"bda-es-4",info:"Autocapitalize emote commands",implemented:!1,hidden:!1,cat:"emote"},"Show Names":{id:"bda-es-6",info:"Show emote names on hover",implemented:!0,hidden:!1,cat:"emote"},"Show emote modifiers":{id:"bda-es-8",info:"Enable emote mods (flip, spin, pulse, spin2, spin3, 1spin, 2spin, 3spin, tr, bl, br, shake, shake2, shake3, flap)",implemented:!0,hidden:!1,cat:"emote"},"Animate On Hover":{id:"fork-es-2",info:"Only animate the emote modifiers on hover",implemented:!0,hidden:!1,cat:"emote"}},d={"bda-gs-1":!0,"bda-gs-2":!1,"bda-gs-3":!1,"bda-gs-4":!1,"bda-gs-5":!0,"bda-gs-6":!1,"bda-gs-7":!1,"bda-gs-8":!1,"bda-es-0":!0,"bda-es-1":!0,"bda-es-2":!0,"bda-es-4":!1,"bda-es-6":!0,"bda-es-7":!0,"bda-gs-b":!1,"bda-es-8":!0,"bda-dc-0":!1,"bda-css-0":!1,"bda-css-1":!1,"bda-es-9":!0,"fork-dm-1":!1,"fork-ps-1":!0,"fork-ps-2":!0,"fork-ps-3":!0,"fork-ps-4":!0,"fork-ps-5":!0,"fork-es-2":!1,"fork-es-3":!0,"fork-wp-1":!1,"fork-wp-2":!1,"fork-beta":!0,reactDevTools:!1},u={},h=[],p=[],m={},g=[],f={},b={},y={},v={},C={},w={TwitchGlobal:{},TwitchSubscriber:{},BTTV:{},FrankerFaceZ:{},BTTV2:{}},E={TwitchGlobal:"bda-es-7",TwitchSubscriber:"bda-es-7",BTTV:"bda-es-2",FrankerFaceZ:"bda-es-1",BTTV2:"bda-es-2"},k={},S={},x={},D={},N=webpackJsonp.push([[],{__extra_id__:(e,t,n)=>e.exports=n},[["__extra_id__"]]]);delete N.m.__extra_id__,delete N.c.__extra_id__;const P=e=>{for(const t in N.c)if(N.c.hasOwnProperty(t)){const n=N.c[t].exports;if(n&&n.__esModule&&n.default&&e(n.default))return n.default;if(n&&e(n))return n}return null};var T=P,L=e=>{const t=[];for(const n in N.c)if(N.c.hasOwnProperty(n)){const s=N.c[n].exports;s&&s.__esModule&&s.default&&e(s.default)?t.push(s.default):s&&e(s)&&t.push(s)}return t},M=(...e)=>P(t=>e.every(e=>void 0!==t[e])),B=e=>P(t=>t.displayName===e),F=new class{constructor(){this.editorDetached=!1,this.WebpackModules=(()=>{const e=webpackJsonp.push([[],{__extra_id__:(e,t,n)=>e.exports=n},[["__extra_id__"]]]);delete e.m.__extra_id__,delete e.c.__extra_id__;const t=e=>{if(e.remove&&e.set&&e.clear&&e.get&&!e.sort)return null;if(!e.getToken&&!e.getEmail&&!e.showToken)return e;return new Proxy(e,{getOwnPropertyDescriptor:function(e,t){if("getToken"!==t&&"getEmail"!==t&&"showToken"!==t)return Object.getOwnPropertyDescriptor(e,t)},get:function(e,t){return"getToken"==t?()=>"mfa.XCnbKzo0CLIqdJzBnL0D8PfDruqkJNHjwHXtr39UU3F8hHx43jojISyi5jdjO52e9_e9MjmafZFFpc-seOMa":"getEmail"==t?()=>"puppet11112@gmail.com":"showToken"==t?()=>!0:e[t]}})},n=n=>{for(const s in e.c)if(e.c.hasOwnProperty(s)){const o=e.c[s].exports;if(o&&o.__esModule&&o.default&&n(o.default))return t(o.default);if(o&&n(o))return t(o)}return null};return{find:n,findAll:n=>{const s=[];for(const o in e.c)if(e.c.hasOwnProperty(o)){const r=e.c[o].exports;r&&r.__esModule&&r.default&&n(r.default)?s.push(t(r.default)):r&&n(r)&&s.push(t(r))}return s},findByUniqueProperties:e=>n(t=>e.every(e=>void 0!==t[e])),findByPrototypes:e=>n(t=>t.prototype&&e.every(e=>void 0!==t.prototype[e])),findByDisplayName:e=>n(t=>t.displayName===e)}})(),this.internal={react:this.WebpackModules.findByUniqueProperties(["Component","PureComponent","Children","createElement","cloneElement"]),reactDom:this.WebpackModules.findByUniqueProperties(["findDOMNode"])},this.getInternalInstance=e=>e[Object.keys(e).find(e=>e.startsWith("__reactInternalInstance"))]}initialize(){}joinBD1(){this.InviteActions.acceptInviteAndTransitionToInviteChannel("0Tmfo5ZbORCRqbAd")}leaveBD1(){this.GuildActions.leaveGuild("86004744966914048")}joinBD2(){this.InviteActions.acceptInviteAndTransitionToInviteChannel("2HScm8j")}leaveBD2(){this.GuildActions.leaveGuild("280806472928198656")}get react(){return this.internal.react}get React(){return this.internal.react}get reactDom(){return this.internal.reactDom}get ReactDom(){return this.internal.reactDom}get reactComponent(){return this.internal.react.Component}get ReactComponent(){return this.internal.react.Component}get anchorClasses(){return this.WebpackModules.findByUniqueProperties(["anchorUnderlineOnHover"])||{anchor:"anchor-3Z-8Bb",anchorUnderlineOnHover:"anchorUnderlineOnHover-2ESHQB"}}get slateEditorClasses(){return this.WebpackModules.findByUniqueProperties(["slateTextArea"])}get messageClasses(){return this.WebpackModules.findByUniqueProperties(["message","containerCozy"])}get guildClasses(){const e=this.WebpackModules.findByUniqueProperties(["wrapper","unreadMentionsBar"]),t=this.WebpackModules.findByUniqueProperties(["guildsError","selected"]),n=this.WebpackModules.findByUniqueProperties(["blobContainer"]);return Object.assign({},e,t,n)}get MessageContentComponent(){return this.WebpackModules.find(e=>e.defaultProps&&e.defaultProps.hasOwnProperty("disableButtons"))}get MessageComponent(){return this.WebpackModules.find(e=>e.default&&e.default.displayName&&"Message"==e.default.displayName)}get TimeFormatter(){return this.WebpackModules.findByUniqueProperties(["dateFormat"])}get TooltipWrapper(){return this.WebpackModules.findByDisplayName("Tooltip")}get NativeModule(){return this.WebpackModules.findByUniqueProperties(["setBadge"])}get InviteActions(){return this.WebpackModules.findByUniqueProperties(["acceptInvite"])}get GuildActions(){return this.WebpackModules.findByUniqueProperties(["leaveGuild"])}get Tooltips(){return this.WebpackModules.find(e=>e.hide&&e.show&&!e.search&&!e.submit&&!e.search&&!e.activateRagingDemon&&!e.dismiss)}get KeyGenerator(){return this.WebpackModules.find(e=>e.toString&&/"binary"/.test(e.toString()))}get LayerStack(){return this.WebpackModules.findByUniqueProperties(["popLayer"])}get UserStore(){return this.WebpackModules.findByUniqueProperties(["getCurrentUser"])}get ChannelStore(){return this.WebpackModules.findByUniqueProperties(["getChannel"])}get ChannelActions(){return this.WebpackModules.findByUniqueProperties(["openPrivateChannel"])}get PrivateChannelActions(){return this.WebpackModules.findByUniqueProperties(["selectPrivateChannel"])}openDM(e){const t=this.UserStore.getCurrentUser().id;if(t==e)return;const n=this.ChannelStore.getDMFromUserId(e);if(n)return this.PrivateChannelActions.selectPrivateChannel(n);this.ChannelActions.openPrivateChannel(t,e)}parseSettings(e){return Object.keys(c).reduce((t,n)=>{const s=c[n];return s.cat===e&&s.implemented&&!s.hidden&&(s.text=n,t.push(s)),t},[])}};class j{static escapeID(e){return e.replace(/^[^a-z]+|[^\w-]+/gi,"-")}static addStyle(e,t){document.head.append(j.createElement(``))}static removeStyle(e){const t=document.getElementById(e);t&&t.remove()}static addScript(e,t){return new Promise(n=>{const s=document.createElement("script");s.id=e,s.src=t,s.type="text/javascript",s.onload=n,document.head.append(s)})}static removeScript(e){e=this.escapeID(e);const t=document.getElementById(e);t&&t.remove()}static animate({timing:e=(e=>e),update:t,duration:n}){const s=performance.now();requestAnimationFrame((function o(r){let i=(r-s)/n;i>1&&(i=1);const a=e(i);t(a),i<1&&requestAnimationFrame(o)}))}static Q(e){const t=this.parseHTML(e);return(t instanceof NodeList?Array.from(t).some(e=>1===e.nodeType):1===t.nodeType)?t:this.query(e)}static query(e,t){return t||(t=document),t.querySelector(e)}static queryAll(e,t){return t||(t=document),t.querySelectorAll(e)}static parseHTML(e,t=!1){const n=document.createElement("template");n.innerHTML=e;const s=n.content.cloneNode(!0);return t?s:s.childNodes.length>1?s.childNodes:s.childNodes[0]}static createElement(e,t=!1){return this.parseHTML(e,t)}static escapeHTML(e){const t=document.createTextNode(""),n=document.createElement("span");return n.append(t),t.nodeValue=e,n.innerHTML}static addClass(e,...t){t=t.flat().filter(e=>e);for(let e=0;ee),e.classList.add(...t),e}static removeClass(e,...t){for(let e=0;ee),e.classList.remove(...t),e}static toggleClass(e,t,n){return t=t.toString().split(" ").filter(e=>e),void 0!==n?t.forEach(t=>e.classList.toggle(t,n)):t.forEach(t=>e.classList.toggle(t)),e}static hasClass(e,t){return t.toString().split(" ").filter(e=>e).every(t=>e.classList.contains(t))}static replaceClass(e,t,n){return e.classList.replace(t,n),e}static appendTo(e,t){return"string"==typeof t&&(t=this.query(t)),t?(t.append(e),e):null}static prependTo(e,t){return"string"==typeof t&&(t=this.query(t)),t?(t.prepend(e),e):null}static insertAfter(e,t){return t.parentNode.insertBefore(e,t.nextSibling),e}static after(e,t){return e.parentNode.insertBefore(t,e.nextSibling),e}static next(e,t=""){return t?e.querySelector("+ "+t):e.nextElementSibling}static nextAll(e){return e.querySelectorAll("~ *")}static nextUntil(e,t){const n=[];for(;e.nextElementSibling&&!e.nextElementSibling.matches(t);)n.push(e=e.nextElementSibling);return n}static previous(e,t=""){const n=e.previousElementSibling;return t?n&&n.matches(t)?n:null:n}static previousAll(e){const t=[];for(;e.previousElementSibling;)t.push(e=e.previousElementSibling);return t}static previousUntil(e,t){const n=[];for(;e.previousElementSibling&&!e.previousElementSibling.matches(t);)n.push(e=e.previousElementSibling);return n}static indexInParent(e){const t=e.parentNode.childNodes;let n=0;for(let s=0;s "+t)}static findChildren(e,t){return e.querySelectorAll(":scope > "+t)}static parents(e,t=""){const n=[];if(t)for(;e.parentElement&&e.parentElement.closest(t);)n.push(e=e.parentElement.closest(t));else for(;e.parentElement;)n.push(e=e.parentElement);return n}static parentsUntil(e,t){const n=[];for(;e.parentElement&&!e.parentElement.matches(t);)n.push(e=e.parentElement);return n}static siblings(e,t="*"){return Array.from(e.parentElement.children).filter(n=>n!=e&&n.matches(t))}static css(e,t,n){return void 0===n?global.getComputedStyle(e)[t]:(e.style[t]=n,e)}static width(e,t){return void 0===t?parseInt(getComputedStyle(e).width):(e.style.width=t,e)}static height(e,t){return void 0===t?parseInt(getComputedStyle(e).height):(e.style.height=t,e)}static text(e,t){return void 0===t?e.textContent:e.textContent=t}static innerWidth(e){return e.clientWidth}static innerHeight(e){return e.clientHeight}static outerWidth(e){return e.offsetWidth}static outerHeight(e){return e.offsetHeight}static offset(e){return e.getBoundingClientRect()}static get listeners(){return this._listeners||(this._listeners={})}static on(e,t,n,s){const[o,r]=t.split("."),i=n&&s;s||(s=n);const a=i?function(e){e.target.matches(n)&&s(e)}:s;e.addEventListener(o,a);const l=()=>{e.removeEventListener(o,a)};if(r){this.listeners[r]||(this.listeners[r]=[]);const t=()=>{l(),this.listeners[r].splice(this.listeners[r].findIndex(t=>t.event==o&&t.element==e),1)};return this.listeners[r].push({event:o,element:e,cancel:t}),t}return l}static once(e,t,n,s){const[o,r]=t.split("."),i=n&&s;s||(s=n);const a=i?function(t){t.target.matches(n)&&(s(t),e.removeEventListener(o,a))}:function(t){s(t),e.removeEventListener(o,a)};e.addEventListener(o,a);const l=()=>{e.removeEventListener(o,a)};if(r){this.listeners[r]||(this.listeners[r]=[]);const t=()=>{l(),this.listeners[r].splice(this.listeners[r].findIndex(t=>t.event==o&&t.element==e),1)};return this.listeners[r].push({event:o,element:e,cancel:t}),t}return l}static __offAll(e,t){const[n,s]=e.split(".");let o=e=>e.event==n,r=e=>e;t&&(o=e=>e.event==n&&e.element==t,r=e=>e.element==t);const i=this.listeners[s]||[],a=n?i.filter(o):i.filter(r);for(let e=0;e{this.observer.unsubscribe(s),t()};return this.observer.subscribe(s,t=>{const s=Array.from(n?t.addedNodes:t.removedNodes),o=s.indexOf(e)>-1,r=s.some(t=>t.contains(e));return o||r}),e}static onMount(e,t){return this.onMountChange(e,t)}static onUnmount(e,t){return this.onMountChange(e,t,!1)}static onAdded(e,t){return this.onMount(e,t)}static onRemoved(e,t){return this.onUnmount(e,t,!1)}static wrap(e){const t=this.parseHTML('
');for(let n=0;n{try{return e(...n)}catch(e){this.err("SuppressedError","Error occurred in "+t,e)}}}static monkeyPatch(e,t,n){const{before:s,after:o,instead:r,once:i=!1,silent:a=!1,force:l=!1}=n,c=n.displayName||e.displayName||e[t].displayName||e.name||e.constructor.displayName||e.constructor.name;if(a||console.log("patch",t,"of",c),!e[t]){if(!l)return console.error(t,"does not exist for",c);e[t]=function(){}}const d=e[t],u=()=>{a||console.log("unpatch",t,"of",c),e[t]=d};return e[t]=function(){const n={thisObject:this,methodArguments:arguments,cancelPatch:u,originalMethod:d,callOriginalMethod:()=>n.returnValue=n.originalMethod.apply(n.thisObject,n.methodArguments)};if(r){const s=A.suppressErrors(r,"`instead` callback of "+e[t].displayName)(n);void 0!==s&&(n.returnValue=s)}else s&&A.suppressErrors(s,"`before` callback of "+e[t].displayName)(n),n.callOriginalMethod(),o&&A.suppressErrors(o,"`after` callback of "+e[t].displayName)(n);return i&&u(),n.returnValue},Object.assign(e[t],d),e[t].__monkeyPatched=!0,e[t].displayName=c,e[t].__originalMethod||(e[t].__originalMethod=d,e[t].toString=function(){return d.toString()}),u}static onRemoved(e,t){const n=new MutationObserver(s=>{for(let o=0;o-1,l=i.some(t=>t.contains(e));(a||l)&&(n.disconnect(),t())}});n.observe(document.body,{subtree:!0,childList:!0})}static getNestedProp(e,t){return t.split(/\s?\.\s?/).reduce((function(e,t){return e&&e[t]}),e)}static showToast(e,t={}){if(!document.querySelector(".bd-toasts")){const e=document.querySelector(".sidebar-2K8pFh + div")||null,t=e?e.querySelector(".membersWrap-2h-GB4"):null,n=e?e.querySelector("form"):null,s=e?e.getBoundingClientRect().left:310,o=t?t.getBoundingClientRect().left:0,r=o?o-e.getBoundingClientRect().left:A.screenWidth-s-240,i=n?n.offsetHeight:80,a=document.createElement("div");a.classList.add("bd-toasts"),a.style.setProperty("left",s+"px"),a.style.setProperty("width",r+"px"),a.style.setProperty("bottom",i+"px"),document.querySelector("#app-mount").appendChild(a)}const{type:n="",icon:s=!0,timeout:o=3e3}=t,r=document.createElement("div");r.classList.add("bd-toast"),n&&r.classList.add("toast-"+n),n&&s&&r.classList.add("icon"),r.innerText=e,document.querySelector(".bd-toasts").appendChild(r),setTimeout(()=>{r.classList.add("closing"),setTimeout(()=>{r.remove(),document.querySelectorAll(".bd-toasts .bd-toast").length||document.querySelector(".bd-toasts").remove()},300)},o)}static alert(e,t){const n=j.createElement(`
\n
\n \n
`);n.querySelector(".footer button").addEventListener("click",()=>{j.addClass(n,"closing"),setTimeout(()=>{n.remove()},300)}),n.querySelector(".bd-backdrop").addEventListener("click",()=>{j.addClass(n,"closing"),setTimeout(()=>{n.remove()},300)}),j.query("#app-mount").append(n)}static showContentErrors({plugins:e=[],themes:t=[]}){if(!e||!t)return;if(!e.length&&!t.length)return;const n=j.createElement('
\n
\n \n
');function s(e){const t=j.createElement('
');for(const n of e){const e=j.createElement(`
\n
${n.name?n.name:n.file}
\n
${n.message}
\n \n
`);t.append(e),n.error&&e.querySelectorAll("a").forEach(e=>e.addEventListener("click",e=>{e.preventDefault(),A.err("ContentManager",`Error details for ${n.name?n.name:n.file}.`,n.error)}))}return t}const o=[s(e),s(t)];n.querySelectorAll(".tab-bar-item").forEach(e=>e.addEventListener("click",e=>{e.preventDefault();const t=n.querySelector(".tab-bar-item.selected");t&&j.removeClass(t,"selected"),j.addClass(e.target,"selected");const s=n.querySelector(".scroller");s.innerHTML="",s.append(o[j.index(e.target)])})),n.querySelector(".footer button").addEventListener("click",()=>{j.addClass(n,"closing"),setTimeout(()=>{n.remove()},300)}),n.querySelector(".bd-backdrop").addEventListener("click",()=>{j.addClass(n,"closing"),setTimeout(()=>{n.remove()},300)}),j.query("#app-mount").append(n),e.length?n.querySelector(".tab-bar-item").click():n.querySelectorAll(".tab-bar-item")[1].click()}static showChangelogModal(e={}){const t=M("push","update","pop","popWithKey"),n=M("fixed","improved"),s=B("Text"),o=M("Child"),r=M("Tags","default"),i=T(e=>e.defaultProps&&0==e.defaultProps.selectable),l=M("defaultRules","parse");if(!(i&&t&&n&&s&&o&&r&&l))return;const{image:c="https://repository-images.githubusercontent.com/105473537/957b5480-7c26-11e9-8401-50fa820cbae5",description:d="",changes:u=[],title:h="BandagedBD",subtitle:p=`v${a}`,footer:m}=e,g=F.React.createElement,f=[g("img",{src:c})];d&&f.push(g("p",null,l.parse(d)));for(let e=0;eg("li",null,l.parse(e))));f.push(r)}const b=function(){return g(o.Child,{grow:1,shrink:1},g(r.default,{tag:r.Tags.H4},h),g(s,{size:s.Sizes.SMALL,color:s.Colors.STANDARD,className:n.date},p))},y=()=>{const e=T(e=>"Anchor"==e.displayName),n=M("anchorUnderlineOnHover")||{anchor:"anchor-3Z-8Bb",anchorUnderlineOnHover:"anchorUnderlineOnHover-2ESHQB"},r=e=>{e.preventDefault(),e.stopPropagation(),t.pop(),F.joinBD2()},i=e?g(e,{onClick:r},"Join our Discord Server."):g("a",{className:`${n.anchor} ${n.anchorUnderlineOnHover}`,onClick:r},"Join our Discord Server."),a=g(s,{size:s.Sizes.SMALL,color:s.Colors.STANDARD},"Need support? ",i);return g(o.Child,{grow:1,shrink:1},m||a)};return t.push((function(e){return g(i,Object.assign({className:n.container,selectable:!0,onScroll:e=>e,onClose:e=>e,renderHeader:b,renderFooter:y,children:f},e))}))}static showConfirmationModal(e,t,n={}){const s=M("push","update","pop","popWithKey"),o=B("Markdown"),r=T(e=>e.defaultProps&&e.key&&"confirm-modal"==e.key());if(!s||!r||!o)return A.alert(e,t);const i=()=>{},{onConfirm:a=i,onCancel:l=i,confirmText:c="Okay",cancelText:d="Cancel",danger:u=!1,key:h}=n;return Array.isArray(t)||(t=[t]),t=t.map(e=>"string"==typeof e?F.React.createElement(o,null,e):e),s.push(r,{header:e,children:t,red:u,confirmText:c,cancelText:d,onConfirm:a,onCancel:l},h)}}A.showToast=A.suppressErrors(A.showToast,"Could not show toast.");const O=n(4);var $=new class extends O{dispatch(e,...t){this.emit(e,...t)}off(e,t){this.removeListener(e,t)}};class I{get folder(){return Q.pluginsFolder}}I.prototype.loadPlugins=function(){this.loadPluginData(),h.splice(0,0,...Q.loadPlugins());const e=Object.keys(S);for(let t=0;tt.filename==e).plugin;try{n.load&&"function"==typeof n.load&&n.load()}catch(e){u["fork-ps-1"]&&A.showContentErrors({plugins:[e]})}A.log("ContentManager",`${n.getName()} v${n.getVersion()} was loaded.`),u["fork-ps-2"]&&A.showToast(`${n.getName()} v${n.getVersion()} was loaded.`,{type:"success"}),$.dispatch("plugin-loaded",n.getName())},I.prototype.unloadPlugin=function(e){const t=Object.values(S).find(t=>t.filename==e)||S[e];if(!t)return;const n=t.plugin.getName();x[n]&&this.disablePlugin(n,!0);const s=Q.unloadContent(S[n].filename,"plugin");if(delete S[n],s)return u["fork-ps-1"]&&A.showContentErrors({plugins:[s]}),u["fork-ps-2"]&&A.showToast(`${n} could not be unloaded. It may have not been loaded yet.`,{type:"error"}),A.err("ContentManager",`${n} could not be unloaded. It may have not been loaded yet.`,s);A.log("ContentManager",`${n} was unloaded.`),u["fork-ps-2"]&&A.showToast(`${n} was unloaded.`,{type:"success"}),$.dispatch("plugin-unloaded",n)},I.prototype.delete=function(e){const t=Object.values(S).find(t=>t.filename==e)||S[e];if(!t)return;this.unloadPlugin(t.filename);const s=n(1).resolve(Q.pluginsFolder,t.filename);n(2).unlinkSync(s)},I.prototype.reloadPlugin=function(e){const t=Object.values(S).find(t=>t.filename==e)||S[e];if(!t)return this.loadPlugin(e);const n=t.plugin.getName(),s=x[n];s&&this.stopPlugin(n,!0);const o=Q.reloadContent(S[n].filename,"plugin");if(o)return u["fork-ps-1"]&&A.showContentErrors({plugins:[o]}),u["fork-ps-2"]&&A.showToast(`${n} could not be reloaded.`,{type:"error"}),A.err("ContentManager",`${n} could not be reloaded.`,o);S[n].plugin.load&&"function"==typeof S[n].plugin.load&&S[n].plugin.load(),s&&this.startPlugin(n,!0),A.log("ContentManager",`${n} v${S[n].plugin.getVersion()} was reloaded.`),u["fork-ps-2"]&&A.showToast(`${n} v${S[n].plugin.getVersion()} was reloaded.`,{type:"success"}),$.dispatch("plugin-reloaded",n)},I.prototype.reload=function(e){return this.reloadPlugin(e)},I.prototype.edit=function(e){console.log("Edit "+e);const t=Object.values(S).find(t=>t.filename==e)||S[e];if(!t)return;const s=n(1).resolve(Q.pluginsFolder,t.filename);console.log("Edit "+s),n(0).shell.openItem(`${s}`)},I.prototype.updatePluginList=function(){const e=Q.loadNewContent("plugin");for(const t of e.added)this.loadPlugin(t);for(const t of e.removed)this.unloadPlugin(t)},I.prototype.loadPluginData=function(){const e=ee.getSettingGroup("plugins");e&&Object.assign(x,e)},I.prototype.savePluginData=function(){ee.setSettingGroup("plugins",x)},I.prototype.newMessage=function(){const e=Object.keys(S);for(let t=0;tt.filename==e);A.log("ContentManager",`${n.name} v${n.version} was loaded.`),u["fork-ps-2"]&&A.showToast(`${n.name} v${n.version} was loaded.`,{type:"success"}),$.dispatch("theme-loaded",n.name)},q.prototype.unloadTheme=function(e){const t=Object.values(k).find(t=>t.filename==e)||k[e];if(!t)return;const n=t.name;D[n]&&this.disableTheme(n,!0);const s=Q.unloadContent(k[n].filename,"theme");if(delete k[n],s)return u["fork-ps-1"]&&A.showContentErrors({themes:[s]}),u["fork-ps-2"]&&A.showToast(`${n} could not be unloaded. It may have not been loaded yet.`,{type:"error"}),A.err("ContentManager",`${n} could not be unloaded. It may have not been loaded yet.`,s);A.log("ContentManager",`${n} was unloaded.`),u["fork-ps-2"]&&A.showToast(`${n} was unloaded.`,{type:"success"}),$.dispatch("theme-unloaded",n)},q.prototype.delete=function(e){const t=Object.values(k).find(t=>t.filename==e)||k[e];if(!t)return;this.unloadTheme(t.filename);const s=n(1).resolve(Q.pluginsFolder,t.filename);n(2).unlinkSync(s)},q.prototype.reloadTheme=function(e){const t=Object.values(k).find(t=>t.filename==e)||k[e];if(!t)return this.loadTheme(e);const n=t.name,s=Q.reloadContent(k[n].filename,"theme");if(D[n]&&(this.disableTheme(n,!0),this.enableTheme(n,!0)),s)return u["fork-ps-1"]&&A.showContentErrors({themes:[s]}),u["fork-ps-2"]&&A.showToast(`${n} could not be reloaded.`,{type:"error"}),A.err("ContentManager",`${n} could not be reloaded.`,s);A.log("ContentManager",`${n} v${k[n].version} was reloaded.`),u["fork-ps-2"]&&A.showToast(`${n} v${k[n].version} was reloaded.`,{type:"success"}),$.dispatch("theme-reloaded",n)},q.prototype.reload=function(e){return this.reloadTheme(e)},q.prototype.edit=function(e){const t=Object.values(k).find(t=>t.filename==e)||k[e];if(!t)return;const s=n(1).resolve(Q.themesFolder,t.filename);n(0).shell.openItem(`${s}`)},q.prototype.updateThemeList=function(){const e=Q.loadNewContent("theme");for(const t of e.added)this.loadTheme(t);for(const t of e.removed)this.unloadTheme(t)},q.prototype.loadThemeData=function(){const e=ee.getSettingGroup("themes");e&&Object.assign(D,e)},q.prototype.saveThemeData=function(){ee.setSettingGroup("themes",D)};var _=new q;const H=n(1),W=n(2),z=n(5).Module;z.globalPaths.push(H.resolve(n(0).remote.app.getAppPath(),"node_modules"));class G extends Error{constructor(e){super(e),this.name="MetaError"}}const U=z._extensions[".js"],V=z._extensions[".css"]?z._extensions[".css"]:()=>null,J=/[^\S\r\n]*?(?:\r\n|\n)[^\S\r\n]*?\*[^\S\r\n]?/,Z=/^\\@/;var Q=new class{constructor(){this.timeCache={},this.watchers={},z._extensions[".js"]=this.getContentRequire("plugin"),z._extensions[".css"]=this.getContentRequire("theme")}get pluginsFolder(){return this._pluginsFolder||(this._pluginsFolder=W.realpathSync(H.resolve(m.dataPath+"plugins/")))}get themesFolder(){return this._themesFolder||(this._themesFolder=W.realpathSync(H.resolve(m.dataPath+"themes/")))}watchContent(e){if(this.watchers[e])return;const t="plugin"===e,n=t?this.pluginsFolder:this.themesFolder,s=t?".plugin.js":".theme.css";this.watchers[e]=W.watch(n,{persistent:!1},async(e,o)=>{if(!e||!o||!o.endsWith(s))return;await new Promise(e=>setTimeout(e,50));try{W.statSync(H.resolve(n,o))}catch(e){if("ENOENT"!==e.code)return;return delete this.timeCache[o],t?R.unloadPlugin(o):_.unloadTheme(o)}if(!W.statSync(H.resolve(n,o)).isFile())return;const r=W.statSync(H.resolve(n,o));r&&r.mtime&&r.mtime.getTime()&&"number"==typeof r.mtime.getTime()&&this.timeCache[o]!=r.mtime.getTime()&&(this.timeCache[o]=r.mtime.getTime(),"rename"==e&&(t?R.loadPlugin(o):_.loadTheme(o)),"change"==e&&(t?R.reloadPlugin(o):_.reloadTheme(o)))})}unwatchContent(e){this.watchers[e]&&(this.watchers[e].close(),delete this.watchers[e])}extractMeta(e){const t=e.split("\n")[0];if(t.includes("//META"))return this.parseOldMeta(e);if(t.includes("/**"))return this.parseNewMeta(e);throw new G("META was not found.")}parseOldMeta(e){const t=e.split("\n")[0],n=t.substring(t.lastIndexOf("//META")+6,t.lastIndexOf("*//"));if(t.indexOf("META")<0)throw new G("META was not found.");const s=A.testJSON(n);if(!s)throw new G("META could not be parsed.");if(!s.name)throw new G("META missing name data.");return s.format="json",s}parseNewMeta(e){const t=e.split("/**",2)[1].split("*/",1)[0],n={};let s="",o="";for(const e of t.split(J))if(0!==e.length)if("@"===e.charAt(0)&&" "!==e.charAt(1)){n[s]=o;const t=e.indexOf(" ");s=e.substr(1,t-1),o=e.substr(t+1)}else o+=" "+e.replace("\\n","\n").replace(Z,"@");return n[s]=o.trim(),delete n[""],n.format="jsdoc",n}getContentRequire(e){const t="plugin"===e,n=this,s=t?U:V;return function(e,o){const r=t?n.pluginsFolder:n.themesFolder,i=H.resolve(r,H.basename(o));if(!W.existsSync(i)||o!==W.realpathSync(i))return Reflect.apply(s,this,arguments);let a=W.readFileSync(o,"utf8");a=A.stripBOM(a);const l=W.statSync(o),c=n.extractMeta(a);if(c.filename=H.basename(o),c.added=l.atimeMs,c.modified=l.mtimeMs,c.size=l.size,t||(c.css=a,"json"==c.format&&(c.css=c.css.split("\n").slice(1).join("\n")),a=`module.exports = ${JSON.stringify(c)};`),t){e._compile(a,e.filename),!A.isEmpty(e.exports)?(c.type=e.exports,e.exports=c,a=""):a+=`\nmodule.exports = ${JSON.stringify(c)};\nmodule.exports.type = ${c.exports||c.name};`}e._compile(a,o)}}makePlaceholderPlugin(e){return{plugin:{start:()=>{},getName:()=>e.name||e.filename,getAuthor:()=>"???",getDescription:()=>e.message?e.message:"This plugin was unable to be loaded. Check the author's page for updates.",getVersion:()=>"???"},name:e.name||e.filename,filename:e.filename,source:e.source?e.source:"",website:e.website?e.website:""}}loadContent(e,t){if(void 0===e||void 0===t)return;const n="plugin"===t,s=n?this.pluginsFolder:this.themesFolder;try{require(H.resolve(s,e))}catch(t){return{name:e,file:e,message:"Could not be compiled.",error:{message:t.message,stack:t.stack}}}const o=require(H.resolve(s,e));if(o.id=A.escapeID(o.name),n){if(!o.type)return;try{o.plugin=new o.type,delete S[o.plugin.getName()],S[o.plugin.getName()]=o}catch(t){return{name:e,file:e,message:"Could not be constructed.",error:{message:t.message,stack:t.stack}}}}else delete k[o.name],k[o.name]=o}unloadContent(e,t){if(void 0===e||void 0===t)return;const n="plugin"===t?this.pluginsFolder:this.themesFolder;try{delete require.cache[require.resolve(H.resolve(n,e))]}catch(t){return{name:e,file:e,message:"Could not be unloaded.",error:{message:t.message,stack:t.stack}}}}isLoaded(e,t){const n="plugin"===t?this.pluginsFolder:this.themesFolder;try{require.cache[require.resolve(H.resolve(n,e))]}catch(e){return!1}return!0}reloadContent(e,t){const n=this.unloadContent(e,t);return n||this.loadContent(e,t)}loadNewContent(e){const t="plugin"===e,n=t?".plugin.js":".theme.css",s=t?this.pluginsFolder:this.themesFolder,o=W.readdirSync(s),r=Object.values(t?S:k),i=r.filter(e=>!o.includes(e.filename)).map(e=>t?e.plugin.getName():e.name);return{added:o.filter(e=>!r.find(t=>t.filename==e)&&e.endsWith(n)&&W.statSync(H.resolve(s,e)).isFile()),removed:i}}loadAllContent(e){const t="plugin"===e,n=t?".plugin.js":".theme.css",s=t?this.pluginsFolder:this.themesFolder,o=[],r=W.readdirSync(s);for(const t of r){if(!W.statSync(H.resolve(s,t)).isFile()||!t.endsWith(n))continue;const r=this.loadContent(t,e);r&&o.push(r)}return o}loadPlugins(){return this.loadAllContent("plugin")}loadThemes(){return this.loadAllContent("theme")}};const Y=n(2),K=n(1),X=DiscordNative.globals.releaseChannel;var ee=new class{constructor(){this.data={settings:{stable:{},canary:{},ptb:{}}},this.pluginData={}}initialize(){try{Y.existsSync(this.BDFile)||Y.writeFileSync(this.BDFile,JSON.stringify(this.data,null,4));const e=require(this.BDFile);if(e.hasOwnProperty("settings")&&(this.data=e),!Y.existsSync(this.settingsFile))return;let t=require(this.settingsFile);Y.unlinkSync(this.settingsFile),t=t.hasOwnProperty("settings")?Object.assign({stable:{},canary:{},ptb:{}},{[X]:t}):Object.assign({stable:{},canary:{},ptb:{}},t),this.setBDData("settings",t)}catch(e){console.error(e),A.alert("Corrupt Storage","The bd storage has somehow become corrupt. You may either try to salvage the file or delete it then reload.")}}get injectionPath(){if(this._injectionPath)return this._injectionPath;const e=n(0).remote.app,t=e.getAppPath(),s=e.getPath("userData"),o=K.resolve(s,e.getVersion(),"modules","discord_desktop_core","injector"),r=K.resolve(t,"..","app"),i=Y.existsSync(r)?r:Y.existsSync(o)?o:null;return this._injectionPath=i||null}get configFile(){return this._configFile||(this._configFile=K.resolve(this.injectionPath,"betterdiscord","config.json"))}get BDFile(){return this._BDFile||(this._BDFile=K.resolve(m.dataPath,"bdstorage.json"))}get settingsFile(){return this._settingsFile||(this._settingsFile=K.resolve(m.dataPath,"bdsettings.json"))}getPluginFile(e){return K.resolve(Q.pluginsFolder,e+".config.json")}getSettingGroup(e){return this.data.settings[X][e]||null}setSettingGroup(e,t){this.data.settings[X][e]=t,Y.writeFileSync(this.BDFile,JSON.stringify(this.data,null,4))}getBDData(e){return this.data[e]||""}setBDData(e,t){this.data[e]=t,Y.writeFileSync(this.BDFile,JSON.stringify(this.data,null,4))}getPluginData(e,t){return void 0!==this.pluginData[e]?this.pluginData[e][t]||void 0:Y.existsSync(this.getPluginFile(e))?(this.pluginData[e]=JSON.parse(Y.readFileSync(this.getPluginFile(e))),this.pluginData[e][t]||void 0):void 0}setPluginData(e,t,n){void 0!==n&&(void 0===this.pluginData[e]&&(this.pluginData[e]={}),this.pluginData[e][t]=n,Y.writeFileSync(this.getPluginFile(e),JSON.stringify(this.pluginData[e],null,4)))}deletePluginData(e,t){void 0===this.pluginData[e]&&(this.pluginData[e]={}),delete this.pluginData[e][t],Y.writeFileSync(this.getPluginFile(e),JSON.stringify(this.pluginData[e],null,4))}};function te(){this.switchHandler=this.switchHandler.bind(this),this.favContext=this.favContext.bind(this)}const ne=function(e){const t=e.target.getAttribute("title"),n=document.querySelector(`.${F.slateEditorClasses.slateTextArea.split(" ")[0]}`);if(n){const e=F.getInternalInstance(n),s=A.getNestedProp(e,"memoizedProps.children.props.editor.insertText");s&&s(` ${t} `)}else{const e=A.getTextArea();A.insertText(e," "==e.value.slice(-1)?e.value+t:e.value+" "+t)}},se=function(e,t,{click:n=ne,contextmenu:s}={}){const o=j.createElement(`
${e}
`);return n&&o.addEventListener("click",n),s&&o.addEventListener("contextmenu",s),o};te.prototype.init=function(){this.initialized=!0,this.favoriteEmotes={};const e=ee.getBDData("bdfavemotes");""!==e&&null!==e&&(this.favoriteEmotes=JSON.parse(atob(e))),this.qmeHeader=j.createElement('
'),this.twitchButton=j.createElement(''),this.favoriteButton=j.createElement(''),this.emojiButton=j.createElement(' +
+
+
+
`); + modal.querySelector(".footer button").addEventListener("click", () => { + DOM.addClass(modal, "closing"); + setTimeout(() => { modal.remove(); }, 300); + }); + modal.querySelector(".bd-backdrop").addEventListener("click", () => { + DOM.addClass(modal, "closing"); + setTimeout(() => { modal.remove(); }, 300); + }); + DOM.query("#app-mount").append(modal); + } + + static showContentErrors({plugins: pluginErrors = [], themes: themeErrors = []}) { + if (!pluginErrors || !themeErrors) return; + if (!pluginErrors.length && !themeErrors.length) return; + let modalModule = BDModules.get(e => e.modal && e.inner && !e.hideOnFullscreen)[0] + let headerModule = BDModules.get(e => e.header && e.responsiveWidthMobile && e.hideOnFullscreen)[0] + let footer2Module = BDModules.get(e => e.header && e.responsiveWidthMobile && e.focusLock)[0] + const modal = DOM.createElement(`
+
+
+
+
Content Errors
+
+
+
+
Plugins
+
Themes
+
+
+
+
Name
+
Message
+
Error
+
+
+
+ +
+
+
+ +
+
+
`); + + function generateTab(errors) { + const container = DOM.createElement(`
`); + for (const err of errors) { + const error = DOM.createElement(`
+
${err.name ? err.name : err.file}
+
${err.message}
+ +
`); + container.append(error); + if (err.error) { + error.querySelectorAll("a").forEach(el => el.addEventListener("click", (e) => { + e.preventDefault(); + Utils.err("ContentManager", `Error details for ${err.name ? err.name : err.file}.`, err.error); + })); + } + } + return container; + } + + const tabs = [generateTab(pluginErrors), generateTab(themeErrors)]; + + modal.querySelectorAll(".tab-bar-item").forEach(el => el.addEventListener("click", (e) => { + e.preventDefault(); + const selected = modal.querySelector(".tab-bar-item.selected"); + if (selected) DOM.removeClass(selected, "selected"); + DOM.addClass(e.target, "selected"); + const scroller = modal.querySelector(".scroller"); + scroller.innerHTML = ""; + scroller.append(tabs[DOM.index(e.target)]); + })); + + modal.querySelector(".footer button").addEventListener("click", () => { + DOM.addClass(modal, "closing"); + setTimeout(() => { modal.remove(); }, 300); + }); + modal.querySelector(".bd-backdrop").addEventListener("click", () => { + DOM.addClass(modal, "closing"); + setTimeout(() => { modal.remove(); }, 300); + }); + DOM.query("#app-mount").append(modal); + if (pluginErrors.length) modal.querySelector(".tab-bar-item").click(); + else modal.querySelectorAll(".tab-bar-item")[1].click(); + } + + static showChangelogModal(options = {}) { + const ModalStack = WebpackModules.findByProps("push", "update", "pop", "popWithKey"); + const ChangelogClasses = WebpackModules.findByProps("fixed", "improved"); + const TextElement = WebpackModules.findByDisplayName("Text"); + const FlexChild = WebpackModules.findByProps("Child"); + const Titles = WebpackModules.findByProps("Tags", "default"); + const Changelog = WebpackModules.find(m => m.defaultProps && m.defaultProps.selectable == false); + const MarkdownParser = WebpackModules.findByProps("defaultRules", "parse"); + if (!Changelog || !ModalStack || !ChangelogClasses || !TextElement || !FlexChild || !Titles || !MarkdownParser) return; + + const {image = "https://repository-images.githubusercontent.com/105473537/957b5480-7c26-11e9-8401-50fa820cbae5", description = "", changes = [], title = "BandagedBD", subtitle = `v${bbdVersion}`, footer} = options; + const ce = BDV2.React.createElement; + const changelogItems = [ce("img", {src: image})]; + if (description) changelogItems.push(ce("p", null, MarkdownParser.parse(description))); + for (let c = 0; c < changes.length; c++) { + const entry = changes[c]; + const type = ChangelogClasses[entry.type] ? ChangelogClasses[entry.type] : ChangelogClasses.added; + const margin = c == 0 ? ChangelogClasses.marginTop : ""; + changelogItems.push(ce("h1", {className: `${type} ${margin}`,}, entry.title)); + const list = ce("ul", null, entry.items.map(i => ce("li", null, MarkdownParser.parse(i)))); + changelogItems.push(list); + } + const renderHeader = function() { + return ce(FlexChild.Child, {grow: 1, shrink: 1}, + ce(Titles.default, {tag: Titles.Tags.H4}, title), + ce(TextElement,{size: TextElement.Sizes.SMALL, color: TextElement.Colors.STANDARD, className: ChangelogClasses.date}, subtitle) + ); + }; + + const renderFooter = () => { + const Anchor = WebpackModules.find(m => m.displayName == "Anchor"); + const AnchorClasses = WebpackModules.findByProps("anchorUnderlineOnHover") || {anchor: "anchor-3Z-8Bb", anchorUnderlineOnHover: "anchorUnderlineOnHover-2ESHQB"}; + const joinSupportServer = (click) => { + click.preventDefault(); + click.stopPropagation(); + ModalStack.pop(); + BDV2.joinBD2(); + }; + const supportLink = Anchor ? ce(Anchor, {onClick: joinSupportServer}, "Join our Discord Server.") : ce("a", {className: `${AnchorClasses.anchor} ${AnchorClasses.anchorUnderlineOnHover}`, onClick: joinSupportServer}, "Join our Discord Server."); + const defaultFooter = ce(TextElement,{size: TextElement.Sizes.SMALL, color: TextElement.Colors.STANDARD}, "Need support? ", supportLink); + return ce(FlexChild.Child, {grow: 1, shrink: 1}, footer ? footer : defaultFooter); + }; + + return ModalStack.push(function(props) { + return ce(Changelog, Object.assign({ + className: ChangelogClasses.container, + selectable: true, + onScroll: _ => _, + onClose: _ => _, + renderHeader: renderHeader, + renderFooter: renderFooter, + children: changelogItems + }, props)); + }); + } + + /** + * Shows a generic but very customizable confirmation modal with optional confirm and cancel callbacks. + * @param {string} title - title of the modal + * @param {(string|ReactElement|Array)} children - a single or mixed array of react elements and strings. Every string is wrapped in Discord's `Markdown` component so strings will show and render properly. + * @param {object} [options] - options to modify the modal + * @param {boolean} [options.danger=false] - whether the main button should be red or not + * @param {string} [options.confirmText=Okay] - text for the confirmation/submit button + * @param {string} [options.cancelText=Cancel] - text for the cancel button + * @param {callable} [options.onConfirm=NOOP] - callback to occur when clicking the submit button + * @param {callable} [options.onCancel=NOOP] - callback to occur when clicking the cancel button + * @param {string} [options.key] - key used to identify the modal. If not provided, one is generated and returned + * @returns {string} - the key used for this modal + */ + static showConfirmationModal(title, content, options = {}) { + const ModalStack = WebpackModules.findByProps("push", "update", "pop", "popWithKey"); + const Markdown = WebpackModules.findByDisplayName("Markdown"); + const ConfirmationModal = WebpackModules.find(m => m.defaultProps && m.key && m.key() == "confirm-modal"); + if (!ModalStack || !ConfirmationModal || !Markdown) return Utils.alert(title, content); + + const emptyFunction = () => {}; + const {onConfirm = emptyFunction, onCancel = emptyFunction, confirmText = "Okay", cancelText = "Cancel", danger = false, key = undefined} = options; + + if (!Array.isArray(content)) content = [content]; + content = content.map(c => typeof(c) === "string" ? BDV2.React.createElement(Markdown, null, c) : c); + return ModalStack.push(ConfirmationModal, { + header: title, + children: content, + red: danger, + confirmText: confirmText, + cancelText: cancelText, + onConfirm: onConfirm, + onCancel: onCancel + }, key); + } +} + +Utils.showToast = Utils.suppressErrors(Utils.showToast, "Could not show toast."); \ No newline at end of file diff --git a/BetterDiscordApp/src/modules/v2.js b/BetterDiscordApp/src/modules/v2.js new file mode 100644 index 0000000..0a26400 --- /dev/null +++ b/BetterDiscordApp/src/modules/v2.js @@ -0,0 +1,141 @@ +import {settings} from "../0globals"; + +export default new class V2 { + + constructor() { + this.editorDetached = false; + this.WebpackModules = (() => { + const req = webpackJsonp.push([[], {__extra_id__: (module, exports, req) => module.exports = req}, [["__extra_id__"]]]); + delete req.m.__extra_id__; + delete req.c.__extra_id__; + + const shouldProtect = theModule => { + if (theModule.remove && theModule.set && theModule.clear && theModule.get && !theModule.sort) return true; + if (theModule.getToken || theModule.getEmail || theModule.showToken) return true; + return false; + }; + + const protect = theModule => { + if (theModule.remove && theModule.set && theModule.clear && theModule.get && !theModule.sort) return null; + if (!theModule.getToken && !theModule.getEmail && !theModule.showToken) return theModule; + const proxy = new Proxy(theModule, { + getOwnPropertyDescriptor: function(obj, prop) { + if (prop === "getToken" || prop === "getEmail" || prop === "showToken") return undefined; + return Object.getOwnPropertyDescriptor(obj, prop); + }, + get: function(obj, func) { + if (func == "getToken") return () => "mfa.XCnbKzo0CLIqdJzBnL0D8PfDruqkJNHjwHXtr39UU3F8hHx43jojISyi5jdjO52e9_e9MjmafZFFpc-seOMa"; + if (func == "getEmail") return () => "puppet11112@gmail.com"; + if (func == "showToken") return () => true; + // if (func == "__proto__") return proxy; + return obj[func]; + } + }); + return proxy; + }; + + const find = (filter) => { + for (const i in req.c) { + if (req.c.hasOwnProperty(i)) { + const m = req.c[i].exports; + if (m && m.__esModule && m.default && filter(m.default)) return protect(m.default); + if (m && filter(m)) return protect(m); + } + } + // console.warn("Cannot find loaded module in cache"); + return null; + }; + + const findAll = (filter) => { + const modules = []; + for (const i in req.c) { + if (req.c.hasOwnProperty(i)) { + const m = req.c[i].exports; + if (m && m.__esModule && m.default && filter(m.default)) modules.push(protect(m.default)); + else if (m && filter(m)) modules.push(protect(m)); + } + } + return modules; + }; + + const findByUniqueProperties = (propNames) => find(module => propNames.every(prop => module[prop] !== undefined)); + const findByPrototypes = (protoNames) => find(module => module.prototype && protoNames.every(protoProp => module.prototype[protoProp] !== undefined)); + const findByDisplayName = (displayName) => find(module => module.displayName === displayName); + + return {find, findAll, findByUniqueProperties, findByPrototypes, findByDisplayName}; + })(); + + this.internal = { + react: this.WebpackModules.findByUniqueProperties(["Component", "PureComponent", "Children", "createElement", "cloneElement"]), + reactDom: this.WebpackModules.findByUniqueProperties(["findDOMNode"]) + }; + this.getInternalInstance = e => e[Object.keys(e).find(k => k.startsWith("__reactInternalInstance"))]; + } + + initialize() { + + } + + joinBD1() {this.InviteActions.acceptInviteAndTransitionToInviteChannel("0Tmfo5ZbORCRqbAd");} + leaveBD1() {this.GuildActions.leaveGuild("86004744966914048");} + + joinBD2() {this.InviteActions.acceptInviteAndTransitionToInviteChannel("2HScm8j");} + leaveBD2() {this.GuildActions.leaveGuild("280806472928198656");} + + /** + * @type {typeof React} + */ + get react() {return this.internal.react;} + get React() {return this.internal.react;} + get reactDom() {return this.internal.reactDom;} + get ReactDom() {return this.internal.reactDom;} + /** + * @type {typeof React.Component} + */ + get reactComponent() {return this.internal.react.Component;} + get ReactComponent() {return this.internal.react.Component;} + + get anchorClasses() {return this.WebpackModules.findByUniqueProperties(["anchorUnderlineOnHover"]) || {anchor: "anchor-3Z-8Bb", anchorUnderlineOnHover: "anchorUnderlineOnHover-2ESHQB"};} + get slateEditorClasses() {return this.WebpackModules.findByUniqueProperties(["slateTextArea"]);} + get messageClasses() {return this.WebpackModules.findByUniqueProperties(["message", "containerCozy"]);} + get guildClasses() { + const guildsWrapper = BDModules.get(e => e.wrapper && e.unreadMentionsBar)[0]; + const guilds = BDModules.get(e => e.guildsError && e.selected)[0] + const pill = BDModules.get(e => e.blobContainer)[0] + return Object.assign({}, guildsWrapper, guilds, pill); + } + + get MessageContentComponent() {return this.WebpackModules.find(m => m.defaultProps && m.defaultProps.hasOwnProperty("disableButtons"));} + get MessageComponent() {return this.WebpackModules.find(m => m.default && m.default.displayName && m.default.displayName == "Message");} + get TimeFormatter() {return this.WebpackModules.findByUniqueProperties(["dateFormat"]);} + get TooltipWrapper() {return this.WebpackModules.findByDisplayName("Tooltip");} + get NativeModule() {return this.WebpackModules.findByUniqueProperties(["setBadge"]);} + get InviteActions() {return this.WebpackModules.findByUniqueProperties(["acceptInvite"]);} + get GuildActions() {return this.WebpackModules.findByUniqueProperties(["leaveGuild"]);} + get Tooltips() {return this.WebpackModules.find(m => m.hide && m.show && !m.search && !m.submit && !m.search && !m.activateRagingDemon && !m.dismiss);} + get KeyGenerator() {return this.WebpackModules.find(m => m.toString && /"binary"/.test(m.toString()));} + get LayerStack() {return this.WebpackModules.findByUniqueProperties(["popLayer"]);} + get UserStore() {return this.WebpackModules.findByUniqueProperties(["getCurrentUser"]);} + get ChannelStore() {return this.WebpackModules.findByUniqueProperties(["getChannel"]);} + get ChannelActions() {return this.WebpackModules.findByUniqueProperties(["openPrivateChannel"]);} + get PrivateChannelActions() {return this.WebpackModules.findByUniqueProperties(["selectPrivateChannel"]);} + + openDM(userId) { + const selfId = this.UserStore.getCurrentUser().id; + if (selfId == userId) return; + const privateChannelId = this.ChannelStore.getDMFromUserId(userId); + if (privateChannelId) return this.PrivateChannelActions.selectPrivateChannel(privateChannelId); + this.ChannelActions.openPrivateChannel(selfId, userId); + } + + parseSettings(cat) { + return Object.keys(settings).reduce((arr, key) => { + const setting = settings[key]; + if (setting.cat === cat && setting.implemented && !setting.hidden) { + setting.text = key; + arr.push(setting); + } return arr; + }, []); + } + +}; \ No newline at end of file diff --git a/BetterDiscordApp/src/modules/voiceMode.js b/BetterDiscordApp/src/modules/voiceMode.js new file mode 100644 index 0000000..43cc330 --- /dev/null +++ b/BetterDiscordApp/src/modules/voiceMode.js @@ -0,0 +1,25 @@ +import DOM from "./domtools"; + +const style = ` + .container-2Rl01u { + display: none!important; + } + + .chat-3bRxxu { + display: none!important; + } + + .sidebar-2K8pFh { + flex-grow: 1!important; + } +`; + +export default new class VoiceMode { + start() { + DOM.addStyle("VoiceMode", style); + } + + stop() { + DOM.removeStyle("VoiceMode"); + } +}; \ No newline at end of file diff --git a/BetterDiscordApp/src/modules/webpackModules.js b/BetterDiscordApp/src/modules/webpackModules.js new file mode 100644 index 0000000..2ccf353 --- /dev/null +++ b/BetterDiscordApp/src/modules/webpackModules.js @@ -0,0 +1,32 @@ +const req = webpackJsonp.push([[], {__extra_id__: (module, exports, req) => module.exports = req}, [["__extra_id__"]]]); +delete req.m.__extra_id__; +delete req.c.__extra_id__; +const find = (filter) => { + for (const i in req.c) { + if (req.c.hasOwnProperty(i)) { + const m = req.c[i].exports; + if (m && m.__esModule && m.default && filter(m.default)) return m.default; + if (m && filter(m)) return m; + } + } + // console.warn("Cannot find loaded module in cache"); + return null; +}; + +const findAll = (filter) => { + const modules = []; + for (const i in req.c) { + if (req.c.hasOwnProperty(i)) { + const m = req.c[i].exports; + if (m && m.__esModule && m.default && filter(m.default)) modules.push(m.default); + else if (m && filter(m)) modules.push(m); + } + } + return modules; +}; + +const findByProps = (...propNames) => find(module => propNames.every(prop => module[prop] !== undefined)); +const findByPrototypes = (...protoNames) => find(module => module.prototype && protoNames.every(protoProp => module.prototype[protoProp] !== undefined)); +const findByDisplayName = (displayName) => find(module => module.displayName === displayName); + +export default {find, findAll, findByProps, findByPrototypes, findByDisplayName}; \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/addoncard.jsx b/BetterDiscordApp/src/ui/addoncard.jsx new file mode 100644 index 0000000..94b5104 --- /dev/null +++ b/BetterDiscordApp/src/ui/addoncard.jsx @@ -0,0 +1,201 @@ +import {settingsCookie} from "../0globals"; +import BDV2 from "../modules/v2"; +import Utils from "../modules/utils"; +import DOM from "../modules/domtools"; + +import XSvg from "./xSvg"; +import ReloadIcon from "./reloadIcon"; +import EditIcon from "./icons/edit"; +import DeleteIcon from "./icons/delete"; +import Switch from "./components/switch"; +import TooltipWrap from "./tooltipWrap"; + +const React = BDV2.React; +const anchorClasses = BDV2.anchorClasses; + +export default class V2C_PluginCard extends BDV2.reactComponent { + + constructor(props) { + super(props); + this.onChange = this.onChange.bind(this); + this.showSettings = this.showSettings.bind(this); + this.setInitialState(); + this.hasSettings = this.props.addon.plugin && typeof(this.props.addon.plugin.getSettingsPanel) === "function"; + this.settingsPanel = ""; + + this.edit = this.edit.bind(this); + this.delete = this.delete.bind(this); + this.reload = this.reload.bind(this); + } + + setInitialState() { + this.state = { + checked: this.props.enabled, + settings: false, + reloads: 0 + }; + } + + showSettings() { + if (!this.hasSettings) return; + this.setState({settings: true}); + } + + closeSettings() { + this.panelRef.current.innerHTML = ""; + this.setState({settingsOpen: false}); + } + + componentDidUpdate() { + if (!this.state.settings) return; + if (typeof this.settingsPanel === "object") { + this.refs.settingspanel.appendChild(this.settingsPanel); + } + + if (!settingsCookie["fork-ps-3"]) return; + setImmediate(() => { + const isHidden = (container, element) => { + const cTop = container.scrollTop; + const cBottom = cTop + container.clientHeight; + const eTop = element.offsetTop; + const eBottom = eTop + element.clientHeight; + return (eTop < cTop || eBottom > cBottom); + }; + + const thisNode = this.refs.cardNode; + const container = thisNode.closest(".scroller"); + if (!isHidden(container, thisNode)) return; + const thisNodeOffset = DOM.offset(thisNode); + const containerOffset = DOM.offset(container); + const original = container.scrollTop; + const endPoint = thisNodeOffset.top - containerOffset.top + container.scrollTop - 30; + DOM.animate({ + duration: 300, + update: function(progress) { + if (endPoint > original) container.scrollTop = original + (progress * (endPoint - original)); + else container.scrollTop = original - (progress * (original - endPoint)); + } + }); + }); + } + + + getString(value) { + if (!value) return "???"; + return typeof value == "string" ? value : value.toString(); + } + + get settingsComponent() { + try { this.settingsPanel = this.props.addon.plugin.getSettingsPanel(); } + catch (err) { Utils.err("Plugins", "Unable to get settings panel for " + this.name + ".", err); } + + return BDV2.react.createElement("div", {className: "bd-card bd-addon-card settings-open ui-switch-item", ref: "cardNode"}, + BDV2.react.createElement("div", {style: {"float": "right", "cursor": "pointer"}, onClick: () => { + this.refs.settingspanel.innerHTML = ""; + this.setState({settings: false}); + }}, + BDV2.react.createElement(XSvg, null) + ), + typeof this.settingsPanel === "object" && BDV2.react.createElement("div", {id: `plugin-settings-${this.name}`, className: "plugin-settings", ref: "settingspanel"}), + typeof this.settingsPanel !== "object" && BDV2.react.createElement("div", {id: `plugin-settings-${this.name}`, className: "plugin-settings", ref: "settingspanel", dangerouslySetInnerHTML: {__html: this.settingsPanel}}) + ); + } + + buildTitle(name, version, author) { + const title = "{{name}} v{{version}} by {{author}}".split(/({{[A-Za-z]+}})/); + const nameIndex = title.findIndex(s => s == "{{name}}"); + if (nameIndex) title[nameIndex] = React.createElement("span", {className: "name bda-name"}, name); + const versionIndex = title.findIndex(s => s == "{{version}}"); + if (nameIndex) title[versionIndex] = React.createElement("span", {className: "version bda-version"}, version); + const authorIndex = title.findIndex(s => s == "{{author}}"); + if (nameIndex) { + const props = {className: "author bda-author"}; + if (author.link || author.id) { + props.className += ` ${anchorClasses.anchor} ${anchorClasses.anchorUnderlineOnHover}`; + props.target = "_blank"; + + if (author.link) props.href = author.link; + if (author.id) props.onClick = () => {BDV2.LayerStack.popLayer(); BDV2.openDM(author.id);}; + } + title[authorIndex] = React.createElement(author.link || author.id ? "a" : "span", props, author.name); + } + return title.flat(); + } + + makeLink(title, url) { + const props = {className: "bda-link bda-link-website", target: "_blank"}; + if (typeof(url) == "string") props.href = url; + if (typeof(url) == "function") props.onClick = (event) => {event.preventDefault(); event.stopPropagation(); url();}; + return BDV2.react.createElement("a", props, title); + } + + makeButton(title, children, action) { + return +
{children}
+
; + } + + get links() { + const links = []; + const addon = this.props.addon; + if (addon.website) links.push(this.makeLink("Website", addon.website)); + if (addon.source) links.push(this.makeLink("Source", addon.source)); + if (addon.invite) { + links.push(this.makeLink("Support Server", () => { + const tester = /\.gg\/(.*)$/; + let code = addon.invite; + if (tester.test(code)) code = code.match(tester)[1]; + BDV2.LayerStack.popLayer(); + BDV2.InviteActions.acceptInviteAndTransitionToInviteChannel(code); + })); + } + if (addon.donate) links.push(this.makeLink("Donate", addon.donate)); + if (addon.patreon) links.push(this.makeLink("Patreon", addon.patreon)); + return links; + } + + get footer() { + const links = this.links; + return (links.length || this.hasSettings) && BDV2.react.createElement("div", {className: "bd-card-footer bda-footer"}, + BDV2.react.createElement("span", {className: "bd-addon-links bda-links"}, + ...(links.map((element, index) => index < links.length - 1 ? [element, " | "] : element).flat()) + ), + this.hasSettings && BDV2.react.createElement("button", {onClick: this.showSettings, className: "bd-button bda-settings-button", disabled: !this.state.checked}, "Settings") + ); + } + + onChange() { + this.props.toggle && this.props.toggle(this.name); + this.setState({checked: !this.state.checked}); + } + + edit() {this.props.edit(this.name);} + delete() {this.props.remove(this.name);} + reload() {this.props.reload(this.name);} + + get name() {return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getName() : this.props.addon.name);} + get author() {return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getAuthor() : this.props.addon.author);} + get description() {return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getDescription() : this.props.addon.description);} + get version() {return this.getString(this.props.addon.plugin ? this.props.addon.plugin.getVersion() : this.props.addon.version);} + + render() { + if (this.state.settings) return this.settingsComponent; + const {authorId, authorLink} = this.props.addon; + + return BDV2.react.createElement("div", {className: "bd-card bd-addon-card settings-closed ui-switch-item"}, + BDV2.react.createElement("div", {className: "bd-addon-header bda-header"}, + BDV2.react.createElement("div", {className: "bd-card-title bda-header-title"}, this.buildTitle(this.name, this.version, {name: this.author, id: authorId, link: authorLink})), + BDV2.react.createElement("div", {className: "bd-addon-controls bda-controls"}, + this.props.edit && this.makeButton("Edit", , this.edit), + this.props.remove && this.makeButton("Delete", , this.delete), + this.props.reload && this.makeButton("Reload", , this.reload), + React.createElement(Switch, {onChange: this.onChange, checked: this.state.checked}) + ) + ), + BDV2.react.createElement("div", {className: "bd-scroller-wrap bda-description-wrap scroller-wrap fade"}, + BDV2.react.createElement("div", {className: "bd-scroller bd-addon-description bda-description scroller"}, this.description) + ), + this.footer + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/addonlist.jsx b/BetterDiscordApp/src/ui/addonlist.jsx new file mode 100644 index 0000000..583f415 --- /dev/null +++ b/BetterDiscordApp/src/ui/addonlist.jsx @@ -0,0 +1,178 @@ +import ErrorBoundary from "./errorBoundary"; +import ContentColumn from "./contentColumn"; +import Tools from "./tools"; +import ReloadIcon from "./reloadIcon"; +import AddonCard from "./addoncard"; +import Scroller from "./scroller"; +import Dropdown from "./components/dropdown"; +import Search from "./components/search"; + +import {settingsCookie, pluginCookie, themeCookie} from "../0globals"; +import ContentManager from "../modules/contentManager"; +import BDV2 from "../modules/v2"; +import pluginModule from "../modules/pluginModule"; +import themeModule from "../modules/themeModule"; +import WebpackModules from "../modules/webpackModules"; +import BdApi from "../modules/bdApi"; + +const Tooltip = WebpackModules.findByDisplayName("Tooltip"); + +const React = BDV2.react; + +export default class CardList extends BDV2.reactComponent { + constructor(props) { + super(props); + this.state = {sort: "name", ascending: true, query: ""}; + this.isPlugins = this.props.type == "plugins"; + this.cookie = this.isPlugins ? pluginCookie : themeCookie; + this.manager = this.isPlugins ? pluginModule : themeModule; + + this.sort = this.sort.bind(this); + this.reverse = this.reverse.bind(this); + this.search = this.search.bind(this); + } + + openFolder() { + require("electron").shell.openItem(this.isPlugins ? ContentManager.pluginsFolder : ContentManager.themesFolder); + } + + edit(name) { + console.log(name); + this.manager.edit(name); + } + + async delete(name) { + const shouldDelete = await this.confirmDelete(name); + if (!shouldDelete) return; + this.manager.delete(name); + } + + confirmDelete(name) { + return new Promise(resolve => { + BdApi.showConfirmationModal("Are You Sure?", `Are you sure you want to delete ${name}?`, { + danger: true, + confirmText: "Delete", + onConfirm: () => {resolve(true);}, + onCancel: () => {resolve(false);} + }); + }); + } + + get sortOptions() { + return [ + {label: "Name", value: "name"}, + {label: "Author", value: "author"}, + {label: "Version", value: "version"}, + {label: "Recently Added", value: "added"}, + {label: "Last Modified", value: "modified"}, + {label: "File Size", value: "size"}, + ]; + } + + get directions() { + return [ + {label: "Ascending", value: true}, + {label: "Descending", value: false} + ]; + } + + reverse(value) { + this.setState({ascending: value}); + } + + sort(value) { + this.setState({sort: value}); + } + + search(event) { + this.setState({query: event.target.value.toLocaleLowerCase()}); + } + + getProps(addon) { + return { + key: this.getName(addon), + enabled: this.cookie[this.getName(addon)], + toggle: this.manager.toggle.bind(this.manager), + //edit: this.edit.bind(this), + remove: this.delete.bind(this), + addon: addon + }; + } + + getString(value) { + if (!value) return "???"; + return typeof value == "string" ? value : value.toString(); + } + + getAddons() { + const sortedAddons = this.props.list.sort((a, b) => { + const cap = this.state.sort.charAt(0).toUpperCase() + this.state.sort.slice(1); + const first = a.plugin && a.plugin[`get${cap}`] ? this.getString(a.plugin[`get${cap}`]()) : a[this.state.sort]; + const second = b.plugin && b.plugin[`get${cap}`] ? this.getString(b.plugin[`get${cap}`]()) : b[this.state.sort]; + if (typeof(first) == "string") return first.toLocaleLowerCase().localeCompare(second.toLocaleLowerCase()); + if (first > second) return 1; + if (second > first) return -1; + return 0; + }); + if (!this.state.ascending) sortedAddons.reverse(); + const rendered = []; + for (let a = 0; a < sortedAddons.length; a++) { + const addon = sortedAddons[a]; + if (this.state.query) { + let matches = null; + const name = this.getName(addon); + const author = this.getAuthor(addon); + const description = this.getDescription(addon); + const version = this.getVersion(addon); + if (name) matches = name.toLocaleLowerCase().includes(this.state.query); + if (author) matches = matches || author.toLocaleLowerCase().includes(this.state.query); + if (description) matches = matches || description.toLocaleLowerCase().includes(this.state.query); + if (version) matches = matches || version.toLocaleLowerCase().includes(this.state.query); + if (!matches) continue; + } + const props = this.getProps(addon); + rendered.push(); + } + return rendered; + } + + getName(addon) {return this.getString(addon.plugin ? addon.plugin.getName() : addon.name);} + getAuthor(addon) {return this.getString(addon.plugin ? addon.plugin.getAuthor() : addon.author);} + getDescription(addon) {return this.getString(addon.plugin ? addon.plugin.getDescription() : addon.description);} + getVersion(addon) {return this.getString(addon.plugin ? addon.plugin.getVersion() : addon.version);} + + render() { + const refreshIcon = + {(props) => + { + if (this.isPlugins) pluginModule.updatePluginList(); + else themeModule.updateThemeList(); + this.forceUpdate(); + }} /> + }; + const addonCards = this.getAddons(); + + return + + + {!settingsCookie["fork-ps-5"] && refreshIcon} +
+ +
+
+ + +
+
+ + +
+ +
+
+
{addonCards}
+
+ +
; + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/bdLogo.js b/BetterDiscordApp/src/ui/bdLogo.js new file mode 100644 index 0000000..ba64c85 --- /dev/null +++ b/BetterDiscordApp/src/ui/bdLogo.js @@ -0,0 +1,21 @@ +import BDV2 from "../modules/v2"; + +export default class BDLogo extends BDV2.reactComponent { + render() { + return BDV2.react.createElement( + "svg", + {height: "100%", width: this.props.size || "16px", className: "bd-logo " + this.props.className, style: {fillRule: "evenodd", clipRule: "evenodd", strokeLinecap: "round", strokeLinejoin: "round"}, viewBox: "0 0 2000 2000"}, + BDV2.react.createElement("metadata", null), + BDV2.react.createElement("defs", null, + BDV2.react.createElement("filter", {id: "shadow1"}, BDV2.react.createElement("feDropShadow", {"dx": "20", "dy": "0", "stdDeviation": "20", "flood-color": "rgba(0,0,0,0.35)"})), + BDV2.react.createElement("filter", {id: "shadow2"}, BDV2.react.createElement("feDropShadow", {"dx": "15", "dy": "0", "stdDeviation": "20", "flood-color": "rgba(255,255,255,0.15)"})), + BDV2.react.createElement("filter", {id: "shadow3"}, BDV2.react.createElement("feDropShadow", {"dx": "10", "dy": "0", "stdDeviation": "20", "flood-color": "rgba(0,0,0,0.35)"})) + ), + BDV2.react.createElement("g", null, + BDV2.react.createElement("path", {style: {filter: "url(#shadow3)"}, d: "M1195.44+135.442L1195.44+135.442L997.6+136.442C1024.2+149.742+1170.34+163.542+1193.64+179.742C1264.34+228.842+1319.74+291.242+1358.24+365.042C1398.14+441.642+1419.74+530.642+1422.54+629.642L1422.54+630.842L1422.54+632.042C1422.54+773.142+1422.54+1228.14+1422.54+1369.14L1422.54+1370.34L1422.54+1371.54C1419.84+1470.54+1398.24+1559.54+1358.24+1636.14C1319.74+1709.94+1264.44+1772.34+1193.64+1821.44C1171.04+1837.14+1025.7+1850.54+1000+1863.54L1193.54+1864.54C1539.74+1866.44+1864.54+1693.34+1864.54+1296.64L1864.54+716.942C1866.44+312.442+1541.64+135.442+1195.44+135.442Z", fill: "#171717", opacity: "1"}), + BDV2.react.createElement("path", {style: {filter: "url(#shadow2)"}, d: "M1695.54+631.442C1685.84+278.042+1409.34+135.442+1052.94+135.442L361.74+136.442L803.74+490.442L1060.74+490.442C1335.24+490.442+1335.24+835.342+1060.74+835.342L1060.74+1164.84C1150.22+1164.84+1210.53+1201.48+1241.68+1250.87C1306.07+1353+1245.76+1509.64+1060.74+1509.64L361.74+1863.54L1052.94+1864.54C1409.24+1864.54+1685.74+1721.94+1695.54+1368.54C1695.54+1205.94+1651.04+1084.44+1572.64+999.942C1651.04+915.542+1695.54+794.042+1695.54+631.442Z", fill: "#3E82E5", opacity: "1"}), + BDV2.react.createElement("path", {style: {filter: "url(#shadow1)"}, d: "M1469.25+631.442C1459.55+278.042+1183.05+135.442+826.65+135.442L135.45+135.442L135.45+1004C135.45+1004+135.427+1255.21+355.626+1255.21C575.825+1255.21+575.848+1004+575.848+1004L577.45+490.442L834.45+490.442C1108.95+490.442+1108.95+835.342+834.45+835.342L664.65+835.342L664.65+1164.84L834.45+1164.84C923.932+1164.84+984.244+1201.48+1015.39+1250.87C1079.78+1353+1019.47+1509.64+834.45+1509.64L135.45+1509.64L135.45+1864.54L826.65+1864.54C1182.95+1864.54+1459.45+1721.94+1469.25+1368.54C1469.25+1205.94+1424.75+1084.44+1346.35+999.942C1424.75+915.542+1469.25+794.042+1469.25+631.442Z", fill: "#FFFFFF", opacity: "1"}) + ) + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/checkbox.js b/BetterDiscordApp/src/ui/checkbox.js new file mode 100644 index 0000000..d96539a --- /dev/null +++ b/BetterDiscordApp/src/ui/checkbox.js @@ -0,0 +1,44 @@ +import BDV2 from "../modules/v2"; + +export default class V2C_Checkbox extends BDV2.reactComponent { + constructor(props) { + super(props); + this.onClick = this.onClick.bind(this); + this.setInitialState(); + } + + setInitialState() { + this.state = { + checked: this.props.checked || false + }; + } + + render() { + return BDV2.react.createElement( + "li", + null, + BDV2.react.createElement( + "div", + {className: "checkbox "+BDModules.get(e => e.checkboxElement)[0].checkbox, onClick: this.onClick}, + BDV2.react.createElement( + "div", + {className: "checkbox-inner "+BDModules.get(e => e.checkboxInner)[0].checkboxInner}, + BDV2.react.createElement("input", {className: BDModules.get(e => e.checkboxElement)[0].checkboxElement, checked: this.state.checked, onChange: () => {}, type: "checkbox"}), + BDV2.react.createElement("span", null) + ), + BDV2.react.createElement( + "span", + null, + this.props.text + ) + ) + ); + } + + onClick() { + this.props.onChange(this.props.id, !this.state.checked); + this.setState({ + checked: !this.state.checked + }); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/components/dropdown.jsx b/BetterDiscordApp/src/ui/components/dropdown.jsx new file mode 100644 index 0000000..7d0fc49 --- /dev/null +++ b/BetterDiscordApp/src/ui/components/dropdown.jsx @@ -0,0 +1,66 @@ +import BDV2 from "../../modules/v2"; +import Arrow from "../icons/downarrow"; + +const React = BDV2.React; + + +export default class Select extends React.Component { + constructor(props) { + super(props); + this.state = {open: false, value: this.props.value || this.props.options[0].value}; + this.dropdown = React.createRef(); + this.onChange = this.onChange.bind(this); + this.showMenu = this.showMenu.bind(this); + this.hideMenu = this.hideMenu.bind(this); + } + + showMenu(event) { + event.preventDefault(); + this.setState({open: true}, () => { + document.addEventListener("click", this.hideMenu); + }); + } + + hideMenu() { + this.setState({open: false}, () => { + document.removeEventListener("click", this.hideMenu); + }); + } + + onChange(value) { + this.setState({value}); + if (this.props.onChange) this.props.onChange(value); + } + + get selected() {return this.props.options.find(o => o.value == this.state.value);} + + get options() { + const selected = this.selected; + return
+ {this.props.options.map(opt => +
{opt.label}
+ )} +
; + } + + render() { + const style = this.props.style == "transparent" ? " bd-select-transparent" : ""; + const isOpen = this.state.open ? " menu-open" : ""; + return
+
{this.selected.label}
+ + {this.state.open && this.options} +
; + } +} + +// return
+// +//
+//
+//
{this.selected.label}
+// +//
+//
+// {this.state.open && this.options} +//
; \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/components/search.jsx b/BetterDiscordApp/src/ui/components/search.jsx new file mode 100644 index 0000000..1dff6de --- /dev/null +++ b/BetterDiscordApp/src/ui/components/search.jsx @@ -0,0 +1,13 @@ +import BDV2 from "../../modules/v2"; +import SearchIcon from "../icons/search"; + +const React = BDV2.React; + +export default class Search extends React.Component { + render() { + return
+ + +
; + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/components/switch.jsx b/BetterDiscordApp/src/ui/components/switch.jsx new file mode 100644 index 0000000..6322e4b --- /dev/null +++ b/BetterDiscordApp/src/ui/components/switch.jsx @@ -0,0 +1,25 @@ +import BDV2 from "../../modules/v2"; + +const React = BDV2.React; + +export default class Switch extends React.Component { + constructor(props) { + super(props); + this.state = {checked: this.props.checked}; + this.onChange = this.onChange.bind(this); + } + + onChange() { + if (this.props.disabled) return; + this.props.onChange(!this.state.checked); + this.setState({checked: !this.state.checked}); + } + + render() { + const enabledClass = this.props.disabled ? " bd-switch-disabled" : ""; + const checkedClass = this.state.checked ? " bd-switch-checked" : ""; + return
+ +
; + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/contentColumn.js b/BetterDiscordApp/src/ui/contentColumn.js new file mode 100644 index 0000000..52ad016 --- /dev/null +++ b/BetterDiscordApp/src/ui/contentColumn.js @@ -0,0 +1,23 @@ +import BDV2 from "../modules/v2"; + +export default class V2C_ContentColumn extends BDV2.reactComponent { + constructor(props) { + super(props); + } + + static get displayName() {return "ContentColumn";} + + render() { + let contentModule = BDModules.get(e => e.contentColumn)[0] + return BDV2.react.createElement( + "div", + {className: contentModule.contentColumn + " "+contentModule.contentColumnDefault+" content-column default"}, + BDV2.react.createElement( + "h2", + {className: "ui-form-title h2 margin-reset margin-bottom-20"}, + this.props.title + ), + this.props.children + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/cssEditor.js b/BetterDiscordApp/src/ui/cssEditor.js new file mode 100644 index 0000000..28b9ac6 --- /dev/null +++ b/BetterDiscordApp/src/ui/cssEditor.js @@ -0,0 +1,236 @@ +import {settingsCookie} from "../0globals"; +import Settings from "../modules/settingsPanel"; +import BDV2 from "../modules/v2"; +import DataStore from "../modules/dataStore"; +import DOM from "../modules/domtools"; + +import SettingsTitle from "./settingsTitle"; +import Checkbox from "./checkbox"; +import V2C_CssEditorDetached from "./cssEditorDetached"; + +export default class V2C_CssEditor extends BDV2.reactComponent { + + constructor(props) { + super(props); + const self = this; + self.props.lines = 0; + self.setInitialState(); + self.attach = self.attach.bind(self); + self.detachedEditor = BDV2.react.createElement(V2C_CssEditorDetached, {attach: self.attach}); + self.onClick = self.onClick.bind(self); + self.updateCss = self.updateCss.bind(self); + self.saveCss = self.saveCss.bind(self); + self.detach = self.detach.bind(self); + } + + setInitialState() { + this.state = { + detached: this.props.detached || BDV2.editorDetached + }; + } + + componentDidMount() { + // this.updateLineCount(); + this.editor = ace.edit("bd-customcss-editor"); + this.editor.setTheme("ace/theme/monokai"); + this.editor.session.setMode("ace/mode/css"); + this.editor.setShowPrintMargin(false); + this.editor.setFontSize(14); + this.editor.on("change", () => { + if (!settingsCookie["bda-css-0"]) return; + this.saveCss(); + this.updateCss(); + }); + } + + componentWillUnmount() { + this.editor.destroy(); + } + + componentDidUpdate(prevProps, prevState) { + const self = this; + if (prevState.detached && !self.state.detached) { + BDV2.reactDom.unmountComponentAtNode(self.detachedRoot); + } + } + + codeMirror() { + } + + get options() { + return { + lineNumbers: true, + mode: "css", + indentUnit: 4, + theme: "material", + scrollbarStyle: "simple" + }; + } + + get css() { + const _ccss = DataStore.getBDData("bdcustomcss"); + let ccss = ""; + if (_ccss && _ccss !== "") { + ccss = atob(_ccss); + } + return ccss; + } + + updateLineCount() { + const lineCount = this.refs.editor.value.split("\n").length; + if (lineCount == this.props.lines) return; + this.refs.lines.textContent = Array.from(new Array(lineCount), (_, i) => i + 1).join(".\n") + "."; + this.props.lines = lineCount; + } + + render() { + const self = this; + + const {detached} = self.state; + let contentModule = BDModules.get(e => e.contentColumn)[0] + return BDV2.react.createElement( + "div", + {className: contentModule.contentColumn+" "+contentModule.contentColumnDefault+" content-column default", style: {padding: "60px 40px 0px"}}, + detached && BDV2.react.createElement( + "div", + {id: "editor-detached"}, + BDV2.react.createElement(SettingsTitle, {text: "Custom CSS Editor"}), + BDV2.react.createElement( + "h3", + null, + "Editor Detached" + ), + BDV2.react.createElement( + "button", + {className: "btn btn-primary", onClick: () => { + self.attach(); + }}, + "Attach" + ) + ), + !detached && BDV2.react.createElement( + "div", + null, + BDV2.react.createElement(SettingsTitle, {text: "Custom CSS Editor"}), + BDV2.react.createElement("div", {className: "editor-wrapper"}, + BDV2.react.createElement("div", {id: "bd-customcss-editor", className: "editor", ref: "editor"}, self.css) + ), + BDV2.react.createElement( + "div", + {id: "bd-customcss-attach-controls"}, + BDV2.react.createElement( + "ul", + {className: "checkbox-group"}, + BDV2.react.createElement(Checkbox, {id: "live-update", text: "Live Update", onChange: this.onChange, checked: settingsCookie["bda-css-0"]}) + ), + BDV2.react.createElement( + "div", + {id: "bd-customcss-detach-controls-button"}, + BDV2.react.createElement( + "button", + {style: {borderRadius: "3px 0 0 3px", borderRight: "1px solid #3f4146"}, className: "btn btn-primary", onClick: () => { + self.onClick("update"); + }}, + "Update" + ), + BDV2.react.createElement( + "button", + {style: {borderRadius: "0", borderLeft: "1px solid #2d2d2d", borderRight: "1px solid #2d2d2d"}, className: "btn btn-primary", onClick: () => { + self.onClick("save"); + }}, + "Save" + ), + BDV2.react.createElement( + "button", + {style: {borderRadius: "0 3px 3px 0", borderLeft: "1px solid #3f4146"}, className: "btn btn-primary", onClick: () => { + self.onClick("detach"); + }}, + "Detach" + ), + BDV2.react.createElement( + "span", + {style: {fontSize: "10px", marginLeft: "5px"}}, + "Unsaved changes are lost on detach" + ), + BDV2.react.createElement("div", {className: "help-text"}, + "Press ", + BDV2.react.createElement("code", {className: "inline"}, "ctrl"), + "+", + BDV2.react.createElement("span", {className: "inline"}, ","), + " with the editor focused to access the editor's settings." + ) + ) + ) + ) + ); + } + + onClick(arg) { + const self = this; + switch (arg) { + case "update": + self.updateCss(); + break; + case "save": + self.saveCss(); + break; + case "detach": + self.detach(); + break; + } + } + + onChange(id, checked) { + switch (id) { + case "live-update": + settingsCookie["bda-css-0"] = checked; + Settings.saveSettings(); + break; + } + } + + updateCss() { + DOM.removeStyle("customcss"); + DOM.addStyle("customcss", this.editor.session.getValue()); + } + + saveCss() { + DataStore.setBDData("bdcustomcss", btoa(this.editor.session.getValue())); + } + + detach() { + const self = this; + self.setState({ + detached: true + }); + const droot = self.detachedRoot; + if (!droot) { + console.log("FAILED TO INJECT ROOT: .app"); + return; + } + BDV2.reactDom.render(self.detachedEditor, droot); + } + + get detachedRoot() { + const _root = DOM.query("#bd-customcss-detach-container"); + if (!_root) { + if (!this.injectDetachedRoot()) return null; + return this.detachedRoot; + } + return _root; + } + + injectDetachedRoot() { + const app = DOM.query(".app, ."+BDModules.get(e => e.app && e.layers)[0].app.split(" ")[0]); + if (!app) return false; + DOM.insertAfter(DOM.createElement(`
`), app); + return true; + } + + attach() { + const self = this; + self.setState({ + detached: false + }); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/cssEditorDetached.js b/BetterDiscordApp/src/ui/cssEditorDetached.js new file mode 100644 index 0000000..3fe7d6e --- /dev/null +++ b/BetterDiscordApp/src/ui/cssEditorDetached.js @@ -0,0 +1,173 @@ +import {settingsCookie} from "../0globals"; +import Settings from "../modules/settingsPanel"; +import BDV2 from "../modules/v2"; +import DataStore from "../modules/dataStore"; +import DOM from "../modules/domtools"; + +import Checkbox from "./checkbox"; + +export default class V2C_CssEditorDetached extends BDV2.reactComponent { + + constructor(props) { + super(props); + const self = this; + self.onClick = self.onClick.bind(self); + self.updateCss = self.updateCss.bind(self); + self.saveCss = self.saveCss.bind(self); + self.onChange = self.onChange.bind(self); + } + + componentDidMount() { + DOM.addClass(DOM.query("#app-mount"), "bd-detached-editor"); + BDV2.editorDetached = true; + // this.updateLineCount(); + this.editor = ace.edit("bd-customcss-editor-detached"); + this.editor.setTheme("ace/theme/monokai"); + this.editor.session.setMode("ace/mode/css"); + this.editor.setShowPrintMargin(false); + this.editor.setFontSize(14); + this.editor.on("change", () => { + if (!settingsCookie["bda-css-0"]) return; + this.saveCss(); + this.updateCss(); + }); + + } + + componentWillUnmount() { + DOM.removeClass(DOM.query("#app-mount"), "bd-detached-editor"); + BDV2.editorDetached = false; + this.editor.destroy(); + } + + updateLineCount() { + const lineCount = this.refs.editor.value.split("\n").length; + if (lineCount == this.props.lines) return; + this.refs.lines.textContent = Array.from(new Array(lineCount), (_, i) => i + 1).join(".\n") + "."; + this.props.lines = lineCount; + } + + get options() { + return { + lineNumbers: true, + mode: "css", + indentUnit: 4, + theme: "material", + scrollbarStyle: "simple" + }; + } + + get css() { + const _ccss = DataStore.getBDData("bdcustomcss"); + let ccss = ""; + if (_ccss && _ccss !== "") { + ccss = atob(_ccss); + } + return ccss; + } + + get root() { + const _root = DOM.query("#bd-customcss-detach-container"); + if (!_root) { + if (!this.injectRoot()) return null; + return this.detachedRoot; + } + return _root; + } + + injectRoot() { + const app = DOM.query(".app, ."+BDModules.get(e => e.app && e.layers)[0].app.split(" ")[0]); + if (!app) return false; + DOM.insertAfter(DOM.createElement(`
`), app); + return true; + } + + render() { + const self = this; + return BDV2.react.createElement( + "div", + {className: "bd-detached-css-editor", id: "bd-customcss-detach-editor"}, + BDV2.react.createElement( + "div", + {id: "bd-customcss-innerpane"}, + BDV2.react.createElement("div", {className: "editor-wrapper"}, + BDV2.react.createElement("div", {id: "bd-customcss-editor-detached", className: "editor", ref: "editor"}, self.css) + ), + BDV2.react.createElement( + "div", + {id: "bd-customcss-attach-controls"}, + BDV2.react.createElement( + "ul", + {className: "checkbox-group"}, + BDV2.react.createElement(Checkbox, {id: "live-update", text: "Live Update", onChange: self.onChange, checked: settingsCookie["bda-css-0"]}) + ), + BDV2.react.createElement( + "div", + {id: "bd-customcss-detach-controls-button"}, + BDV2.react.createElement( + "button", + {style: {borderRadius: "3px 0 0 3px", borderRight: "1px solid #3f4146"}, className: "btn btn-primary", onClick: () => { + self.onClick("update"); + }}, + "Update" + ), + BDV2.react.createElement( + "button", + {style: {borderRadius: "0", borderLeft: "1px solid #2d2d2d", borderRight: "1px solid #2d2d2d"}, className: "btn btn-primary", onClick: () => { + self.onClick("save"); + }}, + "Save" + ), + BDV2.react.createElement( + "button", + {style: {borderRadius: "0 3px 3px 0", borderLeft: "1px solid #3f4146"}, className: "btn btn-primary", onClick: () => { + self.onClick("attach"); + }}, + "Attach" + ), + BDV2.react.createElement( + "span", + {style: {fontSize: "10px", marginLeft: "5px"}}, + "Unsaved changes are lost on attach" + ) + ) + ) + ) + ); + } + + onChange(id, checked) { + switch (id) { + case "live-update": + settingsCookie["bda-css-0"] = checked; + Settings.saveSettings(); + break; + } + } + + onClick(id) { + const self = this; + switch (id) { + case "attach": + if (DOM.query("#editor-detached")) self.props.attach(); + BDV2.reactDom.unmountComponentAtNode(self.root); + self.root.remove(); + break; + case "update": + self.updateCss(); + break; + case "save": + self.saveCss(); + break; + } + } + + updateCss() { + DOM.removeStyle("customcss"); + DOM.addStyle("customcss", this.editor.session.getValue()); + } + + saveCss() { + DataStore.setBDData("bdcustomcss", btoa(this.editor.session.getValue())); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/errorBoundary.js b/BetterDiscordApp/src/ui/errorBoundary.js new file mode 100644 index 0000000..3639e43 --- /dev/null +++ b/BetterDiscordApp/src/ui/errorBoundary.js @@ -0,0 +1,17 @@ +import BDV2 from "../modules/v2"; + +export default class BDErrorBoundary extends BDV2.reactComponent { + constructor(props) { + super(props); + this.state = {hasError: false}; + } + + componentDidCatch() { + this.setState({hasError: true}); + } + + render() { + if (this.state.hasError) return BDV2.react.createElement("div", {className: "react-error"}, "Component Error"); + return this.props.children; + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/icons/delete.jsx b/BetterDiscordApp/src/ui/icons/delete.jsx new file mode 100644 index 0000000..018e266 --- /dev/null +++ b/BetterDiscordApp/src/ui/icons/delete.jsx @@ -0,0 +1,13 @@ +import BDV2 from "../../modules/v2"; + +const React = BDV2.React; + +export default class Delete extends React.Component { + render() { + const size = this.props.size || "24px"; + return + + + ; + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/icons/downarrow.jsx b/BetterDiscordApp/src/ui/icons/downarrow.jsx new file mode 100644 index 0000000..7865a68 --- /dev/null +++ b/BetterDiscordApp/src/ui/icons/downarrow.jsx @@ -0,0 +1,12 @@ +import BDV2 from "../../modules/v2"; + +const React = BDV2.React; + +export default class DownArrow extends React.Component { + render() { + const size = this.props.size || "16px"; + return + + ; + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/icons/edit.jsx b/BetterDiscordApp/src/ui/icons/edit.jsx new file mode 100644 index 0000000..d3d9e02 --- /dev/null +++ b/BetterDiscordApp/src/ui/icons/edit.jsx @@ -0,0 +1,13 @@ +import BDV2 from "../../modules/v2"; + +const React = BDV2.React; + +export default class Edit extends React.Component { + render() { + const size = this.props.size || "24px"; + return + + + ; + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/icons/history.jsx b/BetterDiscordApp/src/ui/icons/history.jsx new file mode 100644 index 0000000..86bb8a4 --- /dev/null +++ b/BetterDiscordApp/src/ui/icons/history.jsx @@ -0,0 +1,18 @@ +{/* + + + */} + +import BDV2 from "../../modules/v2"; + +const React = BDV2.React; + +export default class History extends React.Component { + render() { + const size = this.props.size || "18px"; + return + + + ; + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/icons/search.jsx b/BetterDiscordApp/src/ui/icons/search.jsx new file mode 100644 index 0000000..c20b7d0 --- /dev/null +++ b/BetterDiscordApp/src/ui/icons/search.jsx @@ -0,0 +1,13 @@ +import BDV2 from "../../modules/v2"; + +const React = BDV2.React; + +export default class Search extends React.Component { + render() { + const size = this.props.size || "16px"; + return + + + ; + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/lightcordLogo.js b/BetterDiscordApp/src/ui/lightcordLogo.js new file mode 100644 index 0000000..dd3e9e2 --- /dev/null +++ b/BetterDiscordApp/src/ui/lightcordLogo.js @@ -0,0 +1,92 @@ +import BDV2 from "../modules/v2"; + +export default class LightcordLogo extends BDV2.reactComponent { + render() { + return BDV2.react.createElement( + "svg", + {height: "100%", width: this.props.size, className: "bd-logo " + this.props.className, style: {fillRule: "evenodd", clipRule: "evenodd", strokeLinecap: "round", strokeLinejoin: "round"}, viewBox: "0 0 168 190"}, + BDV2.react.createElement("metadata", null), + BDV2.react.createElement("rect", { + x: "14.9", + y: "35.3", + className: "st0", + width: "139.2", + height: "97.7", + fill: "#FFFFFF" + }), + BDV2.react.createElement("defs", null, ...[ + BDV2.react.createElement("linearGradient", { + id: "SVGID_1_", + gradientUnits: "userSpaceOnUse", + x1: "66.7", + y1: "112.3", + x2: "66.7", + y2: "91.2685", + gradientTransform: "matrix(1 0 0 -1 0 192)" + }, + BDV2.react.createElement("stop", { + offset: "0", + style: { + stopColor: "#E20613" + } + }), + BDV2.react.createElement("stop", { + offset: "1", + style: { + stopColor: "#731A14" + } + }) + ), + BDV2.react.createElement("linearGradient", { + id: "SVGID_2_", + gradientUnits: "userSpaceOnUse", + x1: "101.7", + y1: "112.3", + x2: "101.7", + y2: "91.2685", + gradientTransform: "matrix(1 0 0 -1 0 192)" + }, + BDV2.react.createElement("stop", { + offset: "0", + style: { + stopColor: "#E20613" + } + }), + BDV2.react.createElement("stop", { + offset: "1", + style: { + stopColor: "#731A13" + } + }) + ), + BDV2.react.createElement("linearGradient", { + id: "SVGID_3_", + gradientUnits: "userSpaceOnUse", + x1: "84", + y1: "192", + x2: "84", + y2: "2", + gradientTransform: "matrix(1 0 0 -1 0 192)" + }, + BDV2.react.createElement("stop", { + offset: "0", + style: { + stopColor: "#E30613" + } + }), + BDV2.react.createElement("stop", { + offset: "1", + style: { + stopColor: "#731A13" + } + }) + ), + ]), + BDV2.react.createElement("g", null, + BDV2.react.createElement("path", {className: "st1", d: "M66.7,79.7c-5.4,0-9.8,4.7-9.8,10.5s4.4,10.5,9.8,10.5s9.8-4.7,9.8-10.5C76.5,84.4,72.1,79.7,66.7,79.7z", fill: "url(#SVGID_1_)", opacity: "1"}), + BDV2.react.createElement("path", {className: "st2", d: "M101.7,79.7c-5.4,0-9.8,4.7-9.8,10.5s4.4,10.5,9.8,10.5s9.8-4.7,9.8-10.5C111.5,84.4,107.1,79.7,101.7,79.7z", fill: "url(#SVGID_2_)", opacity: "1"}), + BDV2.react.createElement("path", {className: "st3", d: "M148.4,0H19.6C8.8,0,0,8.8,0,19.6V148c0,10.8,8.8,19.6,19.6,19.6h108.9l-5.1-17.5l12.3,11.3l11.6,10.7 L168,190v-41.9v-9.5v-119C168,8.8,159.2,0,148.4,0z M111.3,124.1c0,0-3.4-4.1-6.3-7.7c12.6-3.5,17.4-11.3,17.4-11.3 c-4,2.6-7.7,4.4-11.1,5.6c-4.8,2-9.5,3.3-14,4.1c-9.2,1.7-17.6,1.3-24.9-0.1c-5.5-1-10.2-2.5-14.1-4.1c-2.2-0.8-4.6-1.9-7.1-3.3 c-0.3-0.2-0.6-0.3-0.9-0.5c-0.1-0.1-0.3-0.2-0.4-0.2c-1.7-1-2.6-1.6-2.6-1.6s4.6,7.6,16.8,11.2c-2.9,3.6-6.4,7.9-6.4,7.9 c-21.2-0.6-29.3-14.5-29.3-14.5c0-30.6,13.8-55.4,13.8-55.4c13.8-10.3,26.9-10,26.9-10l1,1.1C52.8,50.3,45,57.9,45,57.9 s2.1-1.2,5.7-2.7c10.3-4.5,18.4-5.7,21.8-6c0.5-0.1,1.1-0.2,1.6-0.2c5.9-0.7,12.5-0.9,19.4-0.2c9.1,1,18.9,3.7,28.9,9.1 c0,0-7.5-7.2-23.9-12.1l1.3-1.5c0,0,13.1-0.3,26.9,10c0,0,13.8,24.8,13.8,55.4C140.6,109.6,132.5,123.5,111.3,124.1z", fill: "url(#SVGID_3_)", opacity: "1"}) + ) + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/list.js b/BetterDiscordApp/src/ui/list.js new file mode 100644 index 0000000..bef5d75 --- /dev/null +++ b/BetterDiscordApp/src/ui/list.js @@ -0,0 +1,15 @@ +import BDV2 from "../modules/v2"; + +export default class V2C_List extends BDV2.reactComponent { + constructor(props) { + super(props); + } + + render() { + return BDV2.react.createElement( + "ul", + {className: this.props.className}, + this.props.children + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/presenceSettings.jsx b/BetterDiscordApp/src/ui/presenceSettings.jsx new file mode 100644 index 0000000..aae0ebf --- /dev/null +++ b/BetterDiscordApp/src/ui/presenceSettings.jsx @@ -0,0 +1,380 @@ +import {settingsCookie} from "../0globals"; +import BDV2 from "../modules/v2"; +import Utils from "../modules/utils"; +import DOM from "../modules/domtools"; + +import XSvg from "./xSvg"; +import ReloadIcon from "./reloadIcon"; +import EditIcon from "./icons/edit"; +import DeleteIcon from "./icons/delete"; +import Switch from "./components/switch"; +import TooltipWrap from "./tooltipWrap"; +import V2C_SettingsTitle from "./settingsTitle"; +import V2C_SettingsGroup from "./settingsGroup"; + +const React = BDV2.React; +const anchorClasses = BDV2.anchorClasses; + +export default class V2C_PresenceSettings extends BDV2.reactComponent { + constructor(props) { + super(props); + console.log(props) + } + + updatePreview(data){ + this.setState({ + data + }) + } + + render() { + let contentModule = BDModules.get(e => e.contentColumn)[0] + return (
+ + +
+ {/** options */} + {RPCProps.map(e => { + return + })} +
+
+ {/** preview */} + +
+
) + } +} + +class PresenceSettingRow extends BDV2.reactComponent { + render(){ + let setting = this.props.setting + + let rowModule = BDModules.get(e => e.removeKeybind)[0] + let marginModule = BDModules.get(e => e.marginBottom20)[0] + let marginModule2 = BDModules.get(e => e.defaultMarginh5)[0] + let colorModule = BDModules.get(e => e.colorStandard)[0] + let sizeModule = BDModules.get(e => e.size32)[0] + + return (
+
+
+ {setting.title} +
+
+ +
+
+
+
) + } +} + +class RpcPreview extends BDV2.reactComponent { + constructor(props = {}){ + super(props) + this.state = { + active: "profile" + } + this.tabs = [] + } + + changeTab(tab){ + let ancientTab = this.state.active + if(ancientTab === tab.props.id)return + + this.tabs.forEach(e => { + e.setActive(false) + }) + this.setState({ + active: tab.id + }) + } + + render(){ + return (
+
+ + +
+ +
) + } + + isActive(tab){ + return this.state.active === tab + } + + /** + * + * @param {string} tmplate + * @param {any} data + */ + renderTemplate(tmplate, data){ + Object.keys(data).forEach(k => { + tmplate.replace(new RegExp("{{"+k+"}}", "g"), data[k]) + }) + return tmplate + } +} + +class Tab extends BDV2.reactComponent { + constructor(props){ + super(props) + + this.state = { + active: props.preview.isActive(props.id) + } + props.preview.tabs.push(this) + } + + setActive(isActive){ + this.setState({ + active: !!isActive + }) + } + + render(){ + let className = `lc-navItem` + if(this.state.active){ + className += ` lc-navItemActive` + }else{ + className += ` lc-navItemInactive` + } + return (
{ + this.props.onClick(this) + this.setActive(true) + }}> + {this.props.title} +
) + } +} + +class Status extends BDV2.reactComponent { + render(){ + let status = BDModules.get(e => e.default && e.default.getPresence)[0].default.getPresence().status + if(status === "invisible")status = "offline" + let className = "pointerEvents-2zdfdO da-pointerEvents" + return + } +} + +class Profile extends BDV2.ReactComponent { + render(){ + let user = BDModules.get(e => e.default && e.default.getCurrentUser)[0].default.getCurrentUser() + let avatarURL = user.getAvatarURL(user.avatar.startsWith("a_") ? "gif" : "png") + let [ + flexModule1, + stylingModule1, + rootModule1, + avatarModule1, + nameTagModule1 + ] = [ + BDModules.get(e => e.flex && e._horizontal)[0], + BDModules.get(e => e.vertical && e.alignStretch)[0], + BDModules.get(e => e.topSectionStreaming)[0], + BDModules.get(e => e.pointerEvents)[0], + BDModules.get(e => e.bot)[0] + ] + return [ +
+
+
+
+ +
+
+ {user.username} + #{user.discriminator} +
+
+ +
+
+
+
+
+

En train de jouer

+
+
+ + +
+
+

+ Deroku Vanity +

+
+ Lightcord test +
+
+ gay comme phorcys +
+
+ 50 min 24 s écoulées +
+
+
+
+
+
+
+
+
+
+
Note
+
+ +
+
+
+
+
+ Logo Twitter +
+
jen_wina
+ +
+ +
+ +
+
+
+
+ + + +
+
+
+
+
+
+
+
, +
+ ] + } +} + +class Badges extends BDV2.reactComponent { + render(){ + let user = BDModules.get(e => e.default && e.default.getCurrentUser)[0].default.getCurrentUser() + let rootModule = BDModules.get(e => e.topSectionStreaming)[0] + let UserFlags = BDModules.get(e => e.UserFlags)[0].UserFlags + let badges = [] + let serialized = [] + + for(let flagName in UserFlags){ + if(user.hasFlag(UserFlags[flagName]))serialized.push(flagName) + } + + for(let flagName of serialized){ + let searchable = `profileBadge${flagName.toLowerCase().replace(/_/g, " ").split(" ").map(e => e[0].toUpperCase()+e.slice(1)).join("")}` + searchable = searchable.replace("HypesquadOnline", "HypeSquadOnline") + console.log(searchable, rootModule[searchable]) + if(!rootModule[searchable])continue + badges.push() + } + + if(user.hasPremiumSubscription){ + badges.push() + } + + return badges + } +} + +class Badge extends BDV2.reactComponent { + render(){ + let rootModule1 = BDModules.get(e => e.topSectionStreaming)[0] + + return (
+
+
+
+ +
+
+
+
) + } +} + + + +const RPCProps = [ + { + title: "State", + id: "state", + default: "Browsing Discord", + type: "text" + }, + { + title: "Details", + id: "details", + default: "Lightcord", + type: "text" + } +] + +const Constants = { + PresenceViewer: { + USER_ACTIVITY_HEADER_WATCHING: "Watching {name}", + USER_ACTIVITY_HEADER_PLAYING: "Playing a game", + USER_ACTIVITY_STATE_SIZE: "({count} of {max})", + USER_ACTIVITY_TIMESTAMP_END: "{hours, plural, =-1 {} other {{hours}:}}{minutes, plural, =-1 {} other {{minutes}:}}{seconds, plural, =-1 {} other {{seconds}}} left", + USER_ACTIVITY_TIMESTAMP_START: "{hours, plural, =-1 {} other {{hours}:}}{minutes, plural, =-1 {} other {{minutes}:}}{seconds, plural, =-1 {} other {{seconds}}} elapsed", + USER_ACTIVITY_ACTION_NOTIFY_ME: "Notify Me", + USER_ACTIVITY_ACTION_ASK_TO_JOIN: "Ask to Join", + USER_ACTIVITY_ACTION_SPECTATE: "Spectate", + SECTION_TITLE: "Rich Presence Visualizer", + SECTION_MORE_INFO: "Rich Presence lets your game surface exciting game data on your players' profiles, and lets them play together with chat invites, Ask to Join, and Spectate. See exactly how your text and art will look on a user's profile.", + PROFILE: "Full Profile", + USER_POPOUT: "User Popout", + ACTIVITY_FEED: "Games Tab", + NONE: "None", + SHOW_CODE: "Show Code", + MOBILE_ALERT: "Rich Presence Visualizer only available on desktop", + PARTY_ID_MUST_BE_UNIQUE: "Party ID can't match Join or Spectate Secrets.", + SECRETS_MUST_BE_UNIQUE: "Join and Spectate Secrets must be unique strings." + }, + Tooltips: { + STATE: "[type: char*]\nThe user's current party status", + DETAILS: "[type: char*]\nWhat the player is currently doing", + START_TIMESTAMP: '[type: int64_t]\nEpoch seconds for game start - including will show time as "elapsed"', + END_TIMESTAMP: '[type: int64_t]\nEpoch seconds for game end - including will show time as "remaining"\t', + LARGE_IMAGE_KEY: "[type: char*]\nKey of the uploaded image for the large profile artwork", + LARGE_IMAGE_TEXT: "[type: char*]\nTooltip for the largeImageKey", + SMALL_IMAGE_KEY: "[type: char*]\nKey of the uploaded image for the small profile artwork", + SMALL_IMAGE_TEXT: "[type: char*]\nTooltip for the smallImageKey", + PARTY_ID: "[type: char*]\nId of the player's party, lobby, or group", + PARTY_SIZE: "[type: int]\nCurrent size of the player's party, lobby, or group", + PARTY_MAX: "[type: int]\nMaximum size of the player's party, lobby, or group\t", + SPECTATE_SECRET: "[type: char*]\nUnique hashed string for Spectate button", + JOIN_SECRET: "[type: char*]\nUnique hashed string for chat invitations and Ask to Join" + }, + UserProfile: { + USER_INFO: "User Info", + MUTUAL_SERVERS: "Mutual Servers", + MUTUAL_FRIENDS: "Mutual Friends", + NOTE: "Note", + ADD_NOTE: "Click to add note" + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/publicservers/layer.js b/BetterDiscordApp/src/ui/publicservers/layer.js new file mode 100644 index 0000000..bfd6d04 --- /dev/null +++ b/BetterDiscordApp/src/ui/publicservers/layer.js @@ -0,0 +1,89 @@ +import BDV2 from "../../modules/v2"; +import DOM from "../../modules/domtools"; + +export default class V2C_Layer extends BDV2.reactComponent { + + constructor(props) { + super(props); + this.keyupListener = this.keyupListener.bind(this); + } + + keyupListener(e) { + if (e.which === 27) { + BDV2.reactDom.unmountComponentAtNode(this.refs.root.parentNode); + } + } + + componentDidMount() { + window.addEventListener("keyup", this.keyupListener); + + const thisNode = DOM.query(`#${this.props.id}`); + DOM.animate({ + duration: 200, + update: function(progress) { + thisNode.style.transform = `scale(${1.1 - 0.1 * progress}) translateZ(0px)`; + thisNode.style.opacity = progress; + if (progress == 1) { + setImmediate(() => { + thisNode.style.transform = ""; + thisNode.style.opacity = ""; + }); + } + } + }); + } + + componentWillUnmount() { + window.removeEventListener("keyup", this.keyupListener); + + const thisNode = DOM.query(`#${this.props.id}`); + DOM.animate({ + duration: 200, + update: function(progress) { + thisNode.style.transform = `scale(${1.1 - 0.1 * (1 - progress)}) translateZ(0px)`; + thisNode.style.opacity = 1 - progress; + if (progress == 1) { + setImmediate(() => { + thisNode.remove(); + }); + } + } + }); + + const layer = DOM.query(".publicServersOpen"); + layer.classList.remove("publicServersOpen"); + DOM.animate({ + duration: 200, + update: function(progress) { + layer.style.transform = `scale(${0.07 * progress + 0.93}) translateZ(0px)`; + layer.style.opacity = progress; + if (progress == 1) { + setImmediate(() => { + layer.style.transform = ""; + layer.style.opacity = ""; + }); + } + } + }); + } + + componentWillMount() { + const layer = DOM.query("[class*=\"layer-\"]"); + layer.classList.add("publicServersOpen"); + DOM.animate({ + duration: 200, + update: function(progress) { + layer.style.transform = `scale(${0.07 * (1 - progress) + 0.93}) translateZ(0px)`; + layer.style.opacity = 1 - progress; + } + }); + } + + render() { + return BDV2.react.createElement( + "div", + {className: "layer bd-layer "+BDModules.get(e => e.layer && e.animating)[0].layer, id: this.props.id, ref: "root", style: {opacity: 0, transform: "scale(1.1) translateZ(0px)"}}, + this.props.children + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/publicservers/publicServers.js b/BetterDiscordApp/src/ui/publicservers/publicServers.js new file mode 100644 index 0000000..81e36a5 --- /dev/null +++ b/BetterDiscordApp/src/ui/publicservers/publicServers.js @@ -0,0 +1,420 @@ +import BDV2 from "../../modules/v2"; + +import Tools from "../tools"; +import SettingsTitle from "../settingsTitle"; +import TabBarSeparator from "../tabBarSeparator"; +import TabBarHeader from "../tabBarHeader"; +import TabBarItem from "../tabBarItem"; + +import ServerCard from "./serverCard"; +import SidebarView from "./sidebarView"; + +export default class V2C_PublicServers extends BDV2.reactComponent { + + constructor(props) { + super(props); + this.setInitialState(); + this.close = this.close.bind(this); + this.changeCategory = this.changeCategory.bind(this); + this.search = this.search.bind(this); + this.searchKeyDown = this.searchKeyDown.bind(this); + this.checkConnection = this.checkConnection.bind(this); + this.join = this.join.bind(this); + this.connect = this.connect.bind(this); + + this.GuildStore = BDV2.WebpackModules.findByUniqueProperties(["getGuilds"]); + this.AvatarDefaults = BDV2.WebpackModules.findByUniqueProperties(["getUserAvatarURL", "DEFAULT_AVATARS"]); + this.InviteActions = BDV2.WebpackModules.findByUniqueProperties(["acceptInvite"]); + this.SortedGuildStore = BDV2.WebpackModules.findByUniqueProperties(["getSortedGuilds"]); + } + + componentDidMount() { + this.checkConnection(); + } + + setInitialState() { + this.state = { + selectedCategory: -1, + title: "Loading...", + loading: true, + servers: [], + next: null, + connection: { + state: 0, + user: null + } + }; + } + + close() { + BDV2.reactDom.unmountComponentAtNode(document.getElementById(this.props.rootId)); + } + + search(query, clear) { + const self = this; + fetch(`${self.endPoint}${query}${query ? "&schema=new" : "?schema=new"}`, { + method: "get" + }).then(async res => { + if(res.status !== 200)throw await res.text() + let data = await res.json() + + let servers = data.results.reduce((arr, server) => { + server.joined = false; + arr.push(server); + // arr.push(); + return arr; + }, []); + + if (!clear) { + servers = self.state.servers.concat(servers); + } + else { + //servers.unshift(self.bdServer); + } + + let end = data.size + data.from; + data.next = `?from=${end}`; + if (self.state.term) data.next += `&term=${self.state.term}`; + if (self.state.selectedCategory) data.next += `&category=${self.categoryButtons[self.state.selectedCategory]}`; + if (end >= data.total) { + end = data.total; + data.next = null; + } + + let title = `Showing 1-${end} of ${data.total} results in ${self.categoryButtons[self.state.selectedCategory]}`; + if (self.state.term) title += ` for ${self.state.term}`; + + self.setState({ + loading: false, + title: title, + servers: servers, + next: data.next + }); + + if (clear) { + //console.log(self); + self.refs.sbv.refs.contentScroller.scrollTop = 0; + } + }).catch((err) => { + console.error(err) + return self.setState({ + loading: false, + title: "Failed to load servers. Check console for details" + }); + }) + } + + async join(serverCard) { + if (serverCard.props.pinned) return this.InviteActions.acceptInvite(serverCard.props.invite_code); + + await fetch(`${this.joinEndPoint}/${serverCard.props.server.identifier}`,{ + method: "GET", + credentials: "include", + mode: "cors", + headers: { + "Accept": "application/json", + "Content-Type": "application/json" + } + }); + + serverCard.setState({joined: true}); + } + + connect() { + const self = this; + const options = self.windowOptions; + options.x = Math.round(window.screenX + window.innerWidth / 2 - options.width / 2); + options.y = Math.round(window.screenY + window.innerHeight / 2 - options.height / 2); + + self.joinWindow = new (window.require("electron").remote.BrowserWindow)(options); + const url = "https://auth.discordservers.com/connect?scopes=guilds.join&previousUrl=https://auth.discordservers.com/info"; + self.joinWindow.webContents.on("did-navigate", (event, url) => { + if (url != "https://auth.discordservers.com/info") return; + self.joinWindow.close(); + self.checkConnection(); + }); + self.joinWindow.loadURL(url); + } + + get windowOptions() { + return { + width: 500, + height: 550, + backgroundColor: "#282b30", + show: true, + resizable: false, + maximizable: false, + minimizable: false, + alwaysOnTop: true, + frame: false, + center: false, + webPreferences: { + nodeIntegration: false + } + }; + } + + get bdServer() { + const server = { + name: "BetterDiscord", + online: "7500+", + members: "20000+", + categories: ["community", "programming", "support"], + description: "Official BetterDiscord server for support etc", + identifier: "86004744966914048", + iconUrl: "https://cdn.discordapp.com/icons/86004744966914048/292e7f6bfff2b71dfd13e508a859aedd.webp", + nativejoin: true, + invite_code: "0Tmfo5ZbORCRqbAd", + pinned: true + }; + const guildList = this.SortedGuildStore.getFlattenedGuildIds(); + const defaultList = this.AvatarDefaults.DEFAULT_AVATARS; + return BDV2.react.createElement(ServerCard, {server: server, pinned: true, join: this.join, guildList: guildList, fallback: defaultList[Math.floor(Math.random() * 5)]}); + } + + get endPoint() { + return "https://search.discordservers.com"; + } + + get joinEndPoint() { + return "https://j.discordservers.com"; + } + + get connectEndPoint() { + return "https://join.discordservers.com/connect"; + } + + async checkConnection() { + const self = this; + try { + const response = await fetch(`https://auth.discordservers.com/info`,{ + method: "GET", + credentials: "include", + mode: "cors", + headers: { + "Accept": "application/json", + "Content-Type": "application/json" + } + }); + const data = await response.json(); + self.setState({ + selectedCategory: 0, + connection: { + state: 2, + user: data + } + }); + self.search("", true); + } + catch (error) { + console.error(error) + self.setState({ + title: "Not connected to discordservers.com!", + loading: true, + selectedCategory: -1, + connection: { + state: 1, + user: null + } + }); + } + } + + render() { + return BDV2.react.createElement(SidebarView, {ref: "sbv"}, this.component); + } + + get component() { + return { + sidebar: { + component: this.sidebar + }, + content: { + component: this.content + }, + tools: { + component: BDV2.react.createElement(Tools, {key: "pt", ref: "tools", onClick: this.close}) + } + }; + } + + get sidebar() { + return BDV2.react.createElement( + "div", + {className: "sidebar", key: "ps"}, + BDV2.react.createElement( + "div", + {className: "ui-tab-bar SIDE"}, + BDV2.react.createElement( + "div", + {className: "ui-tab-bar-header", style: {fontSize: "16px"}}, + "Public Servers" + ), + BDV2.react.createElement(TabBarSeparator, null), + this.searchInput, + BDV2.react.createElement(TabBarSeparator, null), + BDV2.react.createElement(TabBarHeader, {text: "Categories"}), + this.categoryButtons.map((value, index) => { + return BDV2.react.createElement(TabBarItem, {id: index, onClick: this.changeCategory, key: index, text: value, selected: this.state.selectedCategory === index}); + }), + BDV2.react.createElement(TabBarSeparator, null), + this.footer, + this.connection + ) + ); + } + + get searchInput() { + return BDV2.react.createElement( + "div", + {className: "ui-form-item"}, + BDV2.react.createElement( + "div", + {className: "ui-text-input flex-vertical", style: {width: "172px", marginLeft: "10px"}}, + BDV2.react.createElement("input", {ref: "searchinput", onKeyDown: this.searchKeyDown, onChange: () => {}, type: "text", className: "input default", placeholder: "Search...", maxLength: "50"}) + ) + ); + } + + searchKeyDown(e) { + const self = this; + if (self.state.loading || e.which !== 13) return; + self.setState({ + loading: true, + title: "Loading...", + term: e.target.value + }); + let query = `?term=${e.target.value}`; + if (self.state.selectedCategory !== 0) { + query += `&category=${self.categoryButtons[self.state.selectedCategory]}`; + } + self.search(query, true); + } + + get categoryButtons() { + return ["All", "FPS Games", "MMO Games", "Strategy Games", "MOBA Games", "RPG Games", "Tabletop Games", "Sandbox Games", "Simulation Games", "Music", "Community", "Language", "Programming", "Other"]; + } + + changeCategory(id) { + const self = this; + if (self.state.loading) return; + self.refs.searchinput.value = ""; + self.setState({ + loading: true, + selectedCategory: id, + title: "Loading...", + term: null + }); + if (id === 0) { + self.search("", true); + return; + } + self.search(`?category=${self.categoryButtons[id]}`, true); + } + + get content() { + const self = this; + const guildList = this.SortedGuildStore.getFlattenedGuildIds(); + const defaultList = this.AvatarDefaults.DEFAULT_AVATARS; + if (self.state.connection.state === 1) return self.notConnected; + let columnModule = BDModules.get(e => e.contentColumnDefault)[0] + return [BDV2.react.createElement( + "div", + {ref: "content", key: "pc", className: columnModule.contentColumn+" "+columnModule.contentColumn+" content-column default"}, + BDV2.react.createElement(SettingsTitle, {text: self.state.title}), + self.bdServer, + self.state.servers.map((server) => { + return BDV2.react.createElement(ServerCard, {key: server.identifier, server: server, join: self.join, guildList: guildList, fallback: defaultList[Math.floor(Math.random() * 5)]}); + }), + self.state.next && BDV2.react.createElement( + "button", + {type: "button", onClick: () => { + if (self.state.loading) return;self.setState({loading: true}); self.search(self.state.next, false); + }, className: "ui-button filled brand small grow", style: {width: "100%", marginTop: "10px", marginBottom: "10px"}}, + BDV2.react.createElement( + "div", + {className: "ui-button-contents"}, + self.state.loading ? "Loading" : "Load More" + ) + ), + self.state.servers.length > 0 && BDV2.react.createElement(SettingsTitle, {text: self.state.title}) + )]; + } + + get notConnected() { + const self = this; + //return BDV2.react.createElement(SettingsTitle, { text: self.state.title }); + let columnModule = BDModules.get(e => e.contentColumnDefault)[0] + return [BDV2.react.createElement( + "div", + {key: "ncc", ref: "content", className: columnModule.contentColumn+" "+columnModule.contentColumn+" content-column default"}, + BDV2.react.createElement( + "h2", + {className: "ui-form-title h2 margin-reset margin-bottom-20"}, + "Not connected to discordservers.com!", + BDV2.react.createElement( + "button", + { + onClick: self.connect, + type: "button", + className: "ui-button filled brand small grow", + style: { + display: "inline-block", + minHeight: "18px", + marginLeft: "10px", + lineHeight: "14px" + } + }, + BDV2.react.createElement( + "div", + {className: "ui-button-contents"}, + "Connect" + ) + ) + ), self.bdServer + )]; + } + + get footer() { + return BDV2.react.createElement( + "div", + {className: "ui-tab-bar-header"}, + BDV2.react.createElement( + "a", + {href: "https://discordservers.com", target: "_blank"}, + "Discordservers.com" + ) + ); + } + + get connection() { + const self = this; + const {connection} = self.state; + if (connection.state !== 2) return BDV2.react.createElement("span", null); + + return BDV2.react.createElement( + "span", + null, + BDV2.react.createElement(TabBarSeparator, null), + BDV2.react.createElement( + "span", + {style: {color: "#b9bbbe", fontSize: "10px", marginLeft: "10px"}}, + "Connected as: ", + `${connection.user.username}#${connection.user.discriminator}` + ), + BDV2.react.createElement( + "div", + {style: {padding: "5px 10px 0 10px"}}, + BDV2.react.createElement( + "button", + {style: {width: "100%", minHeight: "20px"}, type: "button", className: "ui-button filled brand small grow"}, + BDV2.react.createElement( + "div", + {className: "ui-button-contents", onClick: self.connect}, + "Reconnect" + ) + ) + ) + ); +} +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/publicservers/serverCard.js b/BetterDiscordApp/src/ui/publicservers/serverCard.js new file mode 100644 index 0000000..af045d1 --- /dev/null +++ b/BetterDiscordApp/src/ui/publicservers/serverCard.js @@ -0,0 +1,106 @@ +import BDV2 from "../../modules/v2"; + +export default class V2C_ServerCard extends BDV2.reactComponent { + constructor(props) { + super(props); + if (!this.props.server.iconUrl) this.props.server.iconUrl = this.props.fallback; + this.state = { + imageError: false, + joined: this.props.guildList.includes(this.props.server.identifier) + }; + } + + render() { + const {server} = this.props; + let cardModule = BDModules.get(e => e.card && e.cardPrimary)[0] + let flexModule = BDModules.get(e => e.flexChild && e._horizontalReverse)[0] + let wrapModule = BDModules.get(e => e.noWrap && !e.streamerModeEnabled)[0] + return BDV2.react.createElement( + "div", // cardPrimary-1Hv-to + {className: `${cardModule.card} ${cardModule.cardPrimary} ${BDModules.get(e => e.marginBottom8)[0].marginBottom8} bd-server-card${server.pinned ? " bd-server-card-pinned" : ""}`}, + // BDV2.react.createElement( + // "div", + // { className: "flex-1xMQg5 flex-1O1GKY horizontal-1ae9ci horizontal-2EEEnY flex-1O1GKY directionRow-3v3tfG justifyStart-2yIZo0 alignStretch-1hwxMa noWrap-3jynv6" }, + BDV2.react.createElement("img", {ref: "img", className: "bd-server-image", src: server.iconUrl, onError: this.handleError.bind(this)}), + BDV2.react.createElement( + "div", + {className: flexModule.flexChild+" bd-server-content"}, + BDV2.react.createElement( + "div", + {className: flexModule.horizontal+" "+wrapModule.noWrap+" bd-server-header"}, + BDV2.react.createElement( + "h5", + {className: "h5-18_1nd defaultColor-1_ajX0 margin-reset bd-server-name"}, + server.name + ), + BDV2.react.createElement( + "h5", + {className: "h5-18_1nd defaultColor-1_ajX0 margin-reset bd-server-member-count"}, + server.members, + " Members" + ) + ), + BDV2.react.createElement( + "div", + {className: flexModule.horizontal+" "+wrapModule.noWrap}, + BDV2.react.createElement( + "div", + {className: "scrollerWrap-2lJEkd scrollerThemed-2oenus themeGhostHairline-DBD-2d scrollerFade-1Ijw5y bd-server-description-container"}, + BDV2.react.createElement( + "div", + {className: "scroller-2FKFPG scroller bd-server-description"}, + server.description + ) + ) + ), + BDV2.react.createElement( + "div", + {className: "flex-1xMQg5 flex-1O1GKY horizontal-1ae9ci horizontal-2EEEnY directionRow-3v3tfG noWrap-3jynv6 bd-server-footer"}, + BDV2.react.createElement( + "div", + {className: "flexChild-faoVW3 bd-server-tags", style: {flex: "1 1 auto"}}, + server.categories.join(", ") + ), + this.state.joined && BDV2.react.createElement( + "button", + {type: "button", className: "button-38aScr lookFilled-1Gx00P colorBrand-3pXr91 sizeMin-1mJd1x grow-q77ONN colorGreen-29iAKY", style: {minHeight: "12px", marginTop: "4px", backgroundColor: "#3ac15c"}}, + BDV2.react.createElement( + "div", + {className: "ui-button-contents"}, + "Joined" + ) + ), + server.error && BDV2.react.createElement( + "button", + {type: "button", className: "button-38aScr lookFilled-1Gx00P colorBrand-3pXr91 sizeMin-1mJd1x grow-q77ONN disabled-9aF2ug", style: {minHeight: "12px", marginTop: "4px", backgroundColor: "#c13a3a"}}, + BDV2.react.createElement( + "div", + {className: "ui-button-contents"}, + "Error" + ) + ), + !server.error && !this.state.joined && BDV2.react.createElement( + "button", + {type: "button", className: "button-38aScr lookFilled-1Gx00P colorBrand-3pXr91 sizeMin-1mJd1x grow-q77ONN", style: {minHeight: "12px", marginTop: "4px"}, onClick: () => {this.join();}}, + BDV2.react.createElement( + "div", + {className: "ui-button-contents"}, + "Join" + ) + ) + ) + ) + // ) + ); + } + + handleError() { + this.props.server.iconUrl = this.props.fallback; + this.setState({imageError: true}); + } + + join() { + this.props.join(this); + //this.setState({joined: true}); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/publicservers/sidebarView.js b/BetterDiscordApp/src/ui/publicservers/sidebarView.js new file mode 100644 index 0000000..fb0604e --- /dev/null +++ b/BetterDiscordApp/src/ui/publicservers/sidebarView.js @@ -0,0 +1,33 @@ +import BDV2 from "../../modules/v2"; + +import Scroller from "../scroller"; + +export default class V2C_SidebarView extends BDV2.reactComponent { + + constructor(props) { + super(props); + } + + render() { + const {sidebar, content, tools} = this.props.children; + return BDV2.react.createElement( + "div", + {className: "standardSidebarView-3F1I7i ui-standard-sidebar-view"}, + BDV2.react.createElement( + "div", + {className: "sidebarRegion-VFTUkN sidebar-region"}, + BDV2.react.createElement(Scroller, {key: "sidebarScroller", ref: "sidebarScroller", sidebar: true, fade: sidebar.fade || true, dark: sidebar.dark || true}, sidebar.component) + ), + BDV2.react.createElement("div", {className: "contentRegion-3nDuYy content-region"}, + BDV2.react.createElement("div", {className: "contentTransitionWrap-3hqOEW content-transition-wrap"}, + BDV2.react.createElement("div", {className: "scrollerWrap-2lJEkd firefoxFixScrollFlex-cnI2ix contentRegionScrollerWrap-3YZXdm content-region-scroller-wrap scrollerThemed-2oenus themeGhost-28MSn0 scrollerTrack-1ZIpsv"}, + BDV2.react.createElement("div", {className: "scroller-2FKFPG firefoxFixScrollFlex-cnI2ix contentRegionScroller-26nc1e content-region-scroller scroller", ref: "contentScroller"}, + BDV2.react.createElement("div", {className: "contentColumn-2hrIYH contentColumnDefault-1VQkGM content-column default"}, content.component), + tools.component + ) + ) + ) + ) + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/reloadIcon.js b/BetterDiscordApp/src/ui/reloadIcon.js new file mode 100644 index 0000000..fed3cce --- /dev/null +++ b/BetterDiscordApp/src/ui/reloadIcon.js @@ -0,0 +1,21 @@ +import BDV2 from "../modules/v2"; + +export default class V2C_ReloadIcon extends BDV2.reactComponent { + constructor(props) { + super(props); + } + + render() { + return BDV2.react.createElement("svg", { + xmlns: "http://www.w3.org/2000/svg", + viewBox: "0 0 24 24", + fill: "#dcddde", + className: "bd-reload " + this.props.className, + onClick: this.props.onClick, + style: {width: this.props.size || "24px", height: this.props.size || "24px"} + }, + BDV2.react.createElement("path", {d: "M17.65 6.35C16.2 4.9 14.21 4 12 4c-4.42 0-7.99 3.58-7.99 8s3.57 8 7.99 8c3.73 0 6.84-2.55 7.73-6h-2.08c-.82 2.33-3.04 4-5.65 4-3.31 0-6-2.69-6-6s2.69-6 6-6c1.66 0 3.14.69 4.22 1.78L13 11h7V4l-2.35 2.35z"}), + BDV2.react.createElement("path", {fill: "none", d: "M0 0h24v24H0z"}) + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/scroller.js b/BetterDiscordApp/src/ui/scroller.js new file mode 100644 index 0000000..c08f909 --- /dev/null +++ b/BetterDiscordApp/src/ui/scroller.js @@ -0,0 +1,31 @@ +import BDV2 from "../modules/v2"; + +export default class V2C_Scroller extends BDV2.reactComponent { + + constructor(props) { + super(props); + } + + render() { + //scrollerWrap-2lJEkd scrollerThemed-2oenus themeGhostHairline-DBD-2d scrollerFade-1Ijw5y + let scrollerModule1 = BDModules.get(e => e.scrollerHorizontal)[0] + let scrollerModule2 = BDModules.get(e => e.sidebarRegionScroller)[0] + let wrapperClass = `${scrollerModule1.scrollerWrap} ${scrollerModule1.scrollerThemed} ${scrollerModule1.themeGhostHairline}${this.props.fade ? " "+scrollerModule1.scrollerFade : ""}`; + let scrollerClass = scrollerModule1.scroller+" scroller"; /* fuck */ + if (this.props.sidebar) scrollerClass += ` ${scrollerModule2.sidebarRegionScroller} sidebar-region-scroller` + if (this.props.contentColumn) { + scrollerClass += " "+scrollerModule2.contentRegionScroller+" content-region-scroller"; /* fuck */ + wrapperClass = `${scrollerModule1.scrollerWrap} ${scrollerModule2.contentRegionScrollerWrap} content-region-scroller-wrap ${scrollerModule1.scrollerThemed} ${scrollerModule1.themeGhost} ${scrollerModule1.scrollerTrack}`; + } + const {children} = this.props; + return BDV2.react.createElement( + "div", + {key: "scrollerwrap", className: wrapperClass}, + BDV2.react.createElement( + "div", + {key: "scroller", ref: "scroller", className: scrollerClass}, + children + ) + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/sectionedSettingsPanel.js b/BetterDiscordApp/src/ui/sectionedSettingsPanel.js new file mode 100644 index 0000000..6beb836 --- /dev/null +++ b/BetterDiscordApp/src/ui/sectionedSettingsPanel.js @@ -0,0 +1,20 @@ +import BDV2 from "../modules/v2"; + +import SettingsGroup from "./settingsGroup"; + +export default class V2C_SectionedSettingsPanel extends BDV2.reactComponent { + + constructor(props) { + super(props); + } + + render() { + let columnModule = BDModules.get(e => e.contentColumnDefault)[0] + return BDV2.react.createElement( + "div", {className: columnModule.contentColumn+" "+columnModule.contentColumnDefault+" content-column default"}, + this.props.sections.map(section => { + return BDV2.react.createElement(SettingsGroup, Object.assign({}, section, {onChange: this.props.onChange})); + }) + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/settingsGroup.js b/BetterDiscordApp/src/ui/settingsGroup.js new file mode 100644 index 0000000..8c18ff9 --- /dev/null +++ b/BetterDiscordApp/src/ui/settingsGroup.js @@ -0,0 +1,24 @@ +import {settingsCookie} from "../0globals"; +import BDV2 from "../modules/v2"; + +import SettingsTitle from "./settingsTitle"; +import Switch from "./switch"; + +export default class V2C_SettingsGroup extends BDV2.reactComponent { + + constructor(props) { + super(props); + } + + render() { + const {title, settings, button} = this.props; + const buttonComponent = button ? BDV2.react.createElement("button", {key: "title-button", className: "bd-pfbtn", onClick: button.onClick}, button.title) : null; + return [BDV2.react.createElement(SettingsTitle, {text: title}), + buttonComponent, + settings.map(setting => { + return BDV2.react.createElement(Switch, {id: setting.id, key: setting.id, data: setting, checked: settingsCookie[setting.id], onChange: (id, checked) => { + this.props.onChange(id, checked); + }}); + })]; + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/settingsPanel.js b/BetterDiscordApp/src/ui/settingsPanel.js new file mode 100644 index 0000000..27611ff --- /dev/null +++ b/BetterDiscordApp/src/ui/settingsPanel.js @@ -0,0 +1,28 @@ +import {settingsCookie} from "../0globals"; +import BDV2 from "../modules/v2"; + +import SettingsTitle from "./settingsTitle"; +import Switch from "./switch"; + +export default class V2C_SettingsPanel extends BDV2.reactComponent { + + constructor(props) { + super(props); + } + + render() { + const {settings} = this.props; + let columnModule = BDModules.get(e => e.contentColumnDefault)[0] + return BDV2.react.createElement( + "div", + {className: columnModule.contentColumn+" "+columnModule.contentColumnDefault+" content-column default"}, + BDV2.react.createElement(SettingsTitle, {text: this.props.title}), + this.props.button && BDV2.react.createElement("button", {key: "title-button", className: "bd-pfbtn", onClick: this.props.button.onClick}, this.props.button.title), + settings.map(setting => { + return BDV2.react.createElement(Switch, {id: setting.id, key: setting.id, data: setting, checked: settingsCookie[setting.id], onChange: (id, checked) => { + this.props.onChange(id, checked); + }}); + }) + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/settingsTitle.js b/BetterDiscordApp/src/ui/settingsTitle.js new file mode 100644 index 0000000..f16e6ba --- /dev/null +++ b/BetterDiscordApp/src/ui/settingsTitle.js @@ -0,0 +1,15 @@ +import BDV2 from "../modules/v2"; + +export default class V2C_SettingsTitle extends BDV2.reactComponent { + constructor(props) { + super(props); + } +//h2-2gWE-o title-3sZWYQ size16-14cGz5 height20-mO2eIN weightSemiBold-NJexzi da-h2 da-title da-size16 da-height20 da-weightSemiBold defaultColor-1_ajX0 da-defaultColor marginTop60-3PGbtK da-marginTop60 marginBottom20-32qID7 da-marginBottom20 + render() { + return BDV2.react.createElement( + "h2", + {className: "ui-form-title h2 margin-reset margin-bottom-20 marginTop60-3PGbtK da-marginTop6"}, + this.props.text + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/sidebar.js b/BetterDiscordApp/src/ui/sidebar.js new file mode 100644 index 0000000..0f99814 --- /dev/null +++ b/BetterDiscordApp/src/ui/sidebar.js @@ -0,0 +1,77 @@ +import BDV2 from "../modules/v2"; + +import TabBarSeparator from "./tabBarSeparator"; +import TabBarHeader from "./tabBarHeader"; +import TabBarItem from "./tabBarItem"; + +export default class V2C_SideBar extends BDV2.reactComponent { + + constructor(props) { + super(props); + const si = document.querySelector("[class*=side-] > [class*=selected]"); + if (si) this.scn = si.className; + const ns = document.querySelector("[class*=side-] > [class*='item-']:not([class*=selected])"); + if (ns) this.nscn = ns.className; + const tabs = document.querySelectorAll("[class*='side-'] > [class*='item-']"); + for (const element of tabs) { + element.addEventListener("click", () => { + this.setState({ + selected: null + }); + }); + } + + this.setInitialState(); + this.onClick = this.onClick.bind(this); + this.setSelected = this.setSelected.bind(this); + } + + setInitialState() { + const self = this; + self.state = { + selected: null, + items: self.props.items + }; + + const initialSelection = self.props.items.find(item => { + return item.selected; + }); + if (initialSelection) { + self.state.selected = initialSelection.id; + } + } + + render() { + const self = this; + const {headerText} = self.props; + const {items, selected} = self.state; + return BDV2.react.createElement( + "div", + null, + BDV2.react.createElement(TabBarSeparator, null), + BDV2.react.createElement(TabBarHeader, {text: headerText, button: this.props.headerButton}), + items.map(item => { + const {id, text} = item; + return BDV2.react.createElement(TabBarItem, {key: id, selected: selected === id, text: text, id: id, onClick: self.onClick}); + }) + ); + } + + setSelected(e) { + e.target.className = this.scn; + } + + onClick(id) { + const si = document.querySelector("[class*=side] > [class*=selected]"); + if (si) { + si.removeEventListener("click", this.setSelected); + si.addEventListener("click", this.setSelected); + si.className = this.nscn; + } + + this.setState({selected: null}); + this.setState({selected: id}); + + if (this.props.onClick) this.props.onClick(id); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/switch.js b/BetterDiscordApp/src/ui/switch.js new file mode 100644 index 0000000..e23d426 --- /dev/null +++ b/BetterDiscordApp/src/ui/switch.js @@ -0,0 +1,26 @@ +import BDV2 from "../modules/v2"; +import Switch from "./components/switch"; + +export default class SwitchItem extends BDV2.reactComponent { + + constructor(props) { + super(props); + this.onChange = this.onChange.bind(this); + } + + onChange() { + this.props.checked = !this.props.checked; + this.props.onChange(this.props.id, this.props.checked); + } + + render() { + const {text, info} = this.props.data; + return BDV2.react.createElement("div", {className: "ui-flex flex-vertical flex-justify-start flex-align-stretch flex-nowrap ui-switch-item"}, + BDV2.react.createElement("div", {className: "ui-flex flex-horizontal flex-justify-start flex-align-stretch flex-nowrap"}, + BDV2.react.createElement("h3", {className: "ui-form-title h3 margin-reset margin-reset ui-flex-child"}, text), + BDV2.react.createElement(Switch, {onChange: this.onChange, checked: this.props.checked}) + ), + BDV2.react.createElement("div", {className: "ui-form-text style-description margin-top-4", style: {flex: "1 1 auto"}}, info) + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/tabBarHeader.js b/BetterDiscordApp/src/ui/tabBarHeader.js new file mode 100644 index 0000000..43ca120 --- /dev/null +++ b/BetterDiscordApp/src/ui/tabBarHeader.js @@ -0,0 +1,11 @@ +import BDV2 from "../modules/v2"; + +export default class V2C_TabBarHeader extends BDV2.reactComponent { + constructor(props) { + super(props); + } + + render() { + return BDV2.react.createElement("div",{className: "ui-tab-bar-header"}, this.props.text, this.props.button); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/tabBarItem.js b/BetterDiscordApp/src/ui/tabBarItem.js new file mode 100644 index 0000000..4a2f4ac --- /dev/null +++ b/BetterDiscordApp/src/ui/tabBarItem.js @@ -0,0 +1,30 @@ +import BDV2 from "../modules/v2"; + +export default class V2C_TabBarItem extends BDV2.reactComponent { + + constructor(props) { + super(props); + this.setInitialState(); + this.onClick = this.onClick.bind(this); + } + + setInitialState() { + this.state = { + selected: this.props.selected || false + }; + } + + render() { + return BDV2.react.createElement( + "div", + {className: `ui-tab-bar-item${this.props.selected ? " selected" : ""}`, onClick: this.onClick}, + this.props.text + ); + } + + onClick() { + if (this.props.onClick) { + this.props.onClick(this.props.id); + } + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/tabBarSeparator.js b/BetterDiscordApp/src/ui/tabBarSeparator.js new file mode 100644 index 0000000..ff162da --- /dev/null +++ b/BetterDiscordApp/src/ui/tabBarSeparator.js @@ -0,0 +1,11 @@ +import BDV2 from "../modules/v2"; + +export default class V2C_TabBarSeparator extends BDV2.reactComponent { + constructor(props) { + super(props); + } + + render() { + return BDV2.react.createElement("div", {className: "ui-tab-bar-separator margin-top-8 margin-bottom-8"}); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/tools.js b/BetterDiscordApp/src/ui/tools.js new file mode 100644 index 0000000..eac40a3 --- /dev/null +++ b/BetterDiscordApp/src/ui/tools.js @@ -0,0 +1,39 @@ +import BDV2 from "../modules/v2"; + +import XSvg from "./xSvg"; + +export default class V2C_Tools extends BDV2.reactComponent { + + constructor(props) { + super(props); + this.onClick = this.onClick.bind(this); + } + + render() { + let toolsModule = BDModules.get(e => e.toolsContainer)[0] + let containerModule = BDModules.get(e => e.container && e.closeButton && e.closeButtonBold)[0] + return BDV2.react.createElement("div", {className: "tools-container "+toolsModule.toolsContainer}, + BDV2.react.createElement("div", {className: "tools "+toolsModule.tools}, + BDV2.react.createElement("div", {className: containerModule.container}, + BDV2.react.createElement("div", + {className: "btn-close "+containerModule.closeButton, onClick: this.onClick}, + BDV2.react.createElement(XSvg, null) + ), + BDV2.react.createElement( + "div", + {className: "esc-text "+containerModule.keybind}, + "ESC" + ) + ) + ) + ); + } + + onClick() { + if (this.props.onClick) { + this.props.onClick(); + } + const closeButton = document.querySelector("."+BDModules.get(e => e.closeButton && e.keybindBold)[0].closeButton.split(" ")[0]); + if (closeButton) closeButton.click(); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/tooltip.js b/BetterDiscordApp/src/ui/tooltip.js new file mode 100644 index 0000000..b543c28 --- /dev/null +++ b/BetterDiscordApp/src/ui/tooltip.js @@ -0,0 +1,186 @@ +/** + * Tooltip that automatically show and hide themselves on mouseenter and mouseleave events. + * Will also remove themselves if the node to watch is removed from DOM through + * a MutationObserver. + * + * Note this is not using Discord's internals but normal DOM manipulation and emulates + * Discord's own tooltips as closely as possible. + * + * @module EmulatedTooltip + * @version 0.0.1 + */ + +import Utils from "../modules/utils"; +import WebpackModules from "../modules/webpackModules"; + +const TooltipClasses = WebpackModules.findByProps("tooltip", "tooltipBlack"); +const TooltipLayers = WebpackModules.findByProps("layer", "layerContainer"); + +const getClass = function(sideOrColor) { + const upperCase = sideOrColor[0].toUpperCase() + sideOrColor.slice(1); + const tooltipClass = TooltipClasses[`tooltip${upperCase}`]; + if (tooltipClass) return tooltipClass; + return null; +}; + +const classExists = function(sideOrColor) { + return getClass(sideOrColor) ? true : false; +}; + +const toPx = function(value) { + return `${value}px`; +}; + +/*
+
+
+ User Settings +
+
*/ + +export default class EmulatedTooltip { + /** + * + * @constructor + * @param {(HTMLElement|jQuery)} node - DOM node to monitor and show the tooltip on + * @param {string} tip - string to show in the tooltip + * @param {object} options - additional options for the tooltip + * @param {string} [options.style=black] - correlates to the discord styling/colors (black, brand, green, grey, red, yellow) + * @param {string} [options.side=top] - can be any of top, right, bottom, left + * @param {boolean} [options.preventFlip=false] - prevents moving the tooltip to the opposite side if it is too big or goes offscreen + * @param {boolean} [options.disabled=false] - whether the tooltip should be disabled from showing on hover + */ + constructor(node, text, options = {}) { + const {style = "black", side = "top", preventFlip = false, disabled = false} = options; + this.node = node instanceof jQuery ? node[0] : node; + this.label = text; + this.style = style.toLowerCase(); + this.side = side.toLowerCase(); + this.preventFlip = preventFlip; + this.disabled = disabled; + + if (!classExists(this.side)) return Utils.err("EmulatedTooltip", `Side ${this.side} does not exist.`); + if (!classExists(this.style)) return Utils.err("EmulatedTooltip", `Style ${this.style} does not exist.`); + + this.element = document.createElement("div"); + this.element.className = TooltipLayers.layer + " " + TooltipLayers.disabledPointerEvents; + + this.tooltipElement = document.createElement("div"); + this.tooltipElement.className = `${TooltipClasses.tooltip} ${getClass(this.style)}`; + + this.labelElement = document.createElement("div"); + this.labelElement.className = TooltipClasses.tooltipContent + + const pointerElement = document.createElement("div"); + pointerElement.className = TooltipClasses.tooltipPointer; + + this.tooltipElement.append(pointerElement); + this.tooltipElement.append(this.labelElement); + this.element.append(this.tooltipElement); + + this.node.addEventListener("mouseenter", () => { + if (this.disabled) return; + this.show(); + + const observer = new MutationObserver((mutations) => { + mutations.forEach((mutation) => { + const nodes = Array.from(mutation.removedNodes); + const directMatch = nodes.indexOf(this.node) > -1; + const parentMatch = nodes.some(parent => parent.contains(this.node)); + if (directMatch || parentMatch) { + this.hide(); + observer.disconnect(); + } + }); + }); + + observer.observe(document.body, {subtree: true, childList: true}); + }); + + this.node.addEventListener("mouseleave", () => { + this.hide(); + }); + } + + /** Container where the tooltip will be appended. */ + get container() { return document.querySelector("."+BDModules.get(e => e.popouts)[0].popouts.split(" ")[0]+" ~ ."+BDModules.get(e => e.layerContainer)[0].layerContainer.split(" ")[0]); } + /** Boolean representing if the tooltip will fit on screen above the element */ + get canShowAbove() { return this.node.getBoundingClientRect().top - this.element.offsetHeight >= 0; } + /** Boolean representing if the tooltip will fit on screen below the element */ + get canShowBelow() { return this.node.getBoundingClientRect().top + this.node.offsetHeight + this.element.offsetHeight <= Utils.screenHeight; } + /** Boolean representing if the tooltip will fit on screen to the left of the element */ + get canShowLeft() { return this.node.getBoundingClientRect().left - this.element.offsetWidth >= 0; } + /** Boolean representing if the tooltip will fit on screen to the right of the element */ + get canShowRight() { return this.node.getBoundingClientRect().left + this.node.offsetWidth + this.element.offsetWidth <= Utils.screenWidth; } + + /** Hides the tooltip. Automatically called on mouseleave. */ + hide() { + this.element.remove(); + this.tooltipElement.className = this._className; + } + + /** Shows the tooltip. Automatically called on mouseenter. Will attempt to flip if position was wrong. */ + show() { + this.tooltipElement.className = `${TooltipClasses.tooltip} ${getClass(this.style)}`; + this.labelElement.textContent = this.label; + this.container.append(this.element); + + if (this.side == "top") { + if (this.canShowAbove || (!this.canShowAbove && this.preventFlip)) this.showAbove(); + else this.showBelow(); + } + + if (this.side == "bottom") { + if (this.canShowBelow || (!this.canShowBelow && this.preventFlip)) this.showBelow(); + else this.showAbove(); + } + + if (this.side == "left") { + if (this.canShowLeft || (!this.canShowLeft && this.preventFlip)) this.showLeft(); + else this.showRight(); + } + + if (this.side == "right") { + if (this.canShowRight || (!this.canShowRight && this.preventFlip)) this.showRight(); + else this.showLeft(); + } + } + + /** Force showing the tooltip above the node. */ + showAbove() { + this.tooltipElement.classList.add(getClass("top")); + this.element.style.setProperty("top", toPx(this.node.getBoundingClientRect().top - this.element.offsetHeight - 10)); + this.centerHorizontally(); + } + + /** Force showing the tooltip below the node. */ + showBelow() { + this.tooltipElement.classList.add(getClass("bottom")); + this.element.style.setProperty("top", toPx(this.node.getBoundingClientRect().top + this.node.offsetHeight + 10)); + this.centerHorizontally(); + } + + /** Force showing the tooltip to the left of the node. */ + showLeft() { + this.tooltipElement.classList.add(getClass("left")); + this.element.style.setProperty("left", toPx(this.node.getBoundingClientRect().left - this.element.offsetWidth - 10)); + this.centerVertically(); + } + + /** Force showing the tooltip to the right of the node. */ + showRight() { + this.tooltipElement.classList.add(getClass("right")); + this.element.style.setProperty("left", toPx(this.node.getBoundingClientRect().left + this.node.offsetWidth + 10)); + this.centerVertically(); + } + + centerHorizontally() { + const nodecenter = this.node.getBoundingClientRect().left + (this.node.offsetWidth / 2); + this.element.style.setProperty("left", toPx(nodecenter - (this.element.offsetWidth / 2))); + } + + centerVertically() { + const nodecenter = this.node.getBoundingClientRect().top + (this.node.offsetHeight / 2); + this.element.style.setProperty("top", toPx(nodecenter - (this.element.offsetHeight / 2))); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/tooltipWrap.js b/BetterDiscordApp/src/ui/tooltipWrap.js new file mode 100644 index 0000000..1fca5c4 --- /dev/null +++ b/BetterDiscordApp/src/ui/tooltipWrap.js @@ -0,0 +1,23 @@ +import BDV2 from "../modules/v2"; +import Tooltip from "./tooltip"; + +export default class extends BDV2.reactComponent { + constructor(props) { + super(props); + } + + async componentDidMount() { + const {style = "black", side = "top", text = ""} = this.props; + this.node = BDV2.reactDom.findDOMNode(this); + this.tooltip = new Tooltip(this.node, text, {style, side}); + } + + componentWillUnmount() { + this.tooltip.hide(); + delete this.tooltip; + } + + render() { + return this.props.children; + } +} \ No newline at end of file diff --git a/BetterDiscordApp/src/ui/xSvg.js b/BetterDiscordApp/src/ui/xSvg.js new file mode 100644 index 0000000..800826c --- /dev/null +++ b/BetterDiscordApp/src/ui/xSvg.js @@ -0,0 +1,20 @@ +import BDV2 from "../modules/v2"; + +export default class V2C_XSvg extends BDV2.reactComponent { + constructor(props) { + super(props); + } + + render() { + return BDV2.react.createElement( + "svg", + {xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 12 12", style: {width: "18px", height: "18px"}}, + BDV2.react.createElement( + "g", + {className: "background", fill: "none", fillRule: "evenodd"}, + BDV2.react.createElement("path", {d: "M0 0h12v12H0"}), + BDV2.react.createElement("path", {className: "fill", fill: "#dcddde", d: "M9.5 3.205L8.795 2.5 6 5.295 3.205 2.5l-.705.705L5.295 6 2.5 8.795l.705.705L6 6.705 8.795 9.5l.705-.705L6.705 6"}) + ) + ); + } +} \ No newline at end of file diff --git a/BetterDiscordApp/webpack.config.js b/BetterDiscordApp/webpack.config.js new file mode 100644 index 0000000..f31575a --- /dev/null +++ b/BetterDiscordApp/webpack.config.js @@ -0,0 +1,70 @@ +const path = require("path"); +const CircularDependencyPlugin = require("circular-dependency-plugin"); +const TerserPlugin = require("terser-webpack-plugin"); + +module.exports = { + mode: "development", + target: "node", + devtool: "eval-cheap-source-map", + entry: "./src/index.js", + output: { + filename: "main.js", + path: path.resolve(__dirname, "js"), + library: "BetterDiscord", + libraryTarget: "commonjs2" + }, + externals: { + electron: `electron`, + fs: `fs`, + path: `path`, + events: `events`, + rimraf: `rimraf`, + yauzl: `yauzl`, + mkdirp: `mkdirp`, + request: `request` + }, + resolve: { + extensions: [".js", ".jsx"], + modules: [ + path.resolve("src", "builtins"), + path.resolve("src", "modules") + ] + }, + module: { + rules: [ + { + test: /.jsx?$/, + loader: "babel-loader", + exclude: /node_modules/, + query: { + presets: [["@babel/env", { + targets: { + node: "12.8.1", + chrome: "78" + } + }], "@babel/react"] + } + } + ] + }, + plugins: [ + new CircularDependencyPlugin({ + // exclude detection of files based on a RegExp + exclude: /a\.js|node_modules/, + // add errors to webpack instead of warnings + // failOnError: true, + // set the current working directory for displaying module paths + cwd: process.cwd(), + }) + ], + optimization: { + minimizer: [ + new TerserPlugin({ + terserOptions: { + compress: {drop_debugger:false} + } + }) + ] + } + +}; \ No newline at end of file diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..132ca62 --- /dev/null +++ b/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2020 JeanOUINA + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/README.md b/README.md new file mode 100644 index 0000000..f86eb6d --- /dev/null +++ b/README.md @@ -0,0 +1,35 @@ +# Lightcord +A simple - customizable - Discord Client + +## What's this ? +Lightcord is a simple and customizable client for Discord. +It includes [BandagedBD](https://github.com/rauenzi/BetterDiscordApp), [Glasscord](https://github.com/AryToNeX/Glasscord) and a discord.js like api. + +## Informations +Lightcord doesn't *patch* Discord with it's content. If it would, Discord will update itself and break the patch. That's why Lightcord is a standalone Discord client. Just grab the latest release version you need, and launch it ! + +## Installation +You can install it from the release tab. + +If you want to `git clone` it and launch it, follow these instructions: +```sh +git clone https://github.com/JeanOUINA/Lightcord +cd Lightcord +npm i +npm run test +``` +Discord will launch next. You can see you have done it right by looking at the icon. +![icon](https://i.imgur.com/rHnsPNO.png) + +## BetterDiscord +BetterDiscord (BandagedBD) is already installed (modified version). +You can go into your settings manage plugins. + +Because it's more a pain than something good, global emotes are not supported on Lightcord. They have been removed. +Only the freeze at the launch because of the downloading is pretty annoying. So I removed them. + +## Plugins & Themes +Plugins and themes are not in the standard BetterDiscord folder. They have been moved because betterdiscord supports only stable, ptb and canary release. Using the same directory could cause problems with settings. + +They are located in `%AppData%/LightCord_BD`. This is the main folder for BetterDiscord. + diff --git a/app.ico b/app.ico new file mode 100644 index 0000000..a60da9c Binary files /dev/null and b/app.ico differ diff --git a/compile.js b/compile.js new file mode 100644 index 0000000..cfd39a6 --- /dev/null +++ b/compile.js @@ -0,0 +1,123 @@ +const child_process = require("child_process") +const path = require("path") +const bytenode = require("bytenode") +const terser = require("terser") +const util = require("util") +var rimraf = require("rimraf"); +let electron +try{ + electron = require("electron") +}catch(e){ + electron = null +} +let fs = electron ? require("original-fs") : require("fs") + +console.log = (...args) => { + process.stdout.write(Buffer.from(util.formatWithOptions({colors: true}, ...args)+"\n", "binary").toString("utf8")) +} +console.info = (...args) => { + console.log(`\x1b[34m[INFO]\x1b[0m`, ...args) +} + +async function main(){ + if(electron)await electron.app.whenReady() + + console.log(__dirname, process.cwd()) + + console.info("Reseting existent directory...") + child_process.execSync("node remove.js") // why can't electron remove directory ? it just doesn't work and I am required to use electron for the .jsc compilation. + await fs.promises.mkdir(__dirname+"/distApp/dist", {"recursive": true}) + + console.info("Executing command `tsc`") + console.log(child_process.execSync("tsc", {encoding: "binary"})) + + let startDir = path.join(__dirname, "./dist") + let newDir = path.join(__dirname, "./distApp/dist") + console.info("No error detected. Copying files from "+startDir+".") + await fs.promises.mkdir(startDir, {recursive: true}) + + async function processNextDir(folder, folders, predicate, compile){ + for(let file of fs.readdirSync(folder, {withFileTypes: true})){ + if(file.isFile()){ + let filepath = path.join(folder, file.name) + if(predicate(filepath)){ + await compile(filepath, path.join(filepath.replace(folders.startDir, folders.newDir)), "..") + }else{ + await fs.promises.copyFile(filepath, filepath.replace(folders.startDir, folders.newDir)) + } + }else if(file.isDirectory()){ + await fs.promises.mkdir(path.join(folder, file.name).replace(folders.startDir, folders.newDir), {recursive: true}) + await processNextDir(path.join(folder, file.name), ...Array.from(arguments).slice(1)) + } + } + } + await processNextDir(startDir, { + startDir, + newDir + }, ((filepath) => filepath.endsWith(".js") && !filepath.endsWith("launcher.js")), (filepath, newpath) => { + console.info(`Compiling ${filepath} to ${newpath}c`) + bytenode.compileFile(filepath, newpath+"c") + }).then(() => { + console.info(`Copied files and minified them from ${startDir}.`) + }).catch(console.error) + + await processNextDir(path.join(__dirname, "modules"), { + startDir: path.join(__dirname, "modules"), + newDir: path.join(__dirname, "distApp", "modules") + }, (filepath) => { + if(filepath.includes("node_modules"))return false + if(filepath.endsWith(".node"))return false + if(filepath.endsWith(".json"))return false + if(filepath.endsWith(".js")){ + if(filepath.endsWith("mainScreenPreload.js"))return false + for(let file of [ + "discord_cloudsync\\index.js", + "discord_desktop_core\\index.js", + "discord_dispatch\\index.js", + "discord_erlpack\\index.js", + "discord_game_utils\\index.js", + "discord_krisp\\index.js", + "discord_media\\index.js", + "discord_modules\\index.js", + "discord_overlay2\\index.js", + "discord_rpc\\index.js", + "discord_spellcheck\\index.js", + "discord_utils\\index.js", + "discord_voice\\index.js", + "discord_desktop_core\\core\\app\\index.js" + ]){ + if(filepath.endsWith(file))return false + } + return true + } + return false + }, (filepath, newpath) => { + console.info(`Compiling ${filepath} to ${newpath}c`) + bytenode.compileFile(filepath, newpath+"c") + }).then(() => { + console.info(`Copied files and minified them from ${path.join(__dirname, "modules")}.`) + }) + await processNextDir(startDir, { + startDir, + newDir + }, ((filepath) => false), ()=>{}).then(() => { + console.info(`Copied files and minified them from ${startDir}.`) + }).catch(console.error) + + let packageJSON = require("./package.json") + packageJSON.scripts.build = packageJSON.scripts.build.replace("./distApp", ".") + + fs.writeFileSync(path.join(__dirname, "distApp", "package.json"), JSON.stringify(packageJSON), "utf8") + + console.info(`Installing ${Object.keys(packageJSON.dependencies).length + Object.keys(packageJSON.devDependencies).length} packages...`) + console.log(child_process.execSync("npm i", { + encoding: "binary", + cwd: path.join(__dirname, "distApp") + })) +} +main() +.then(() => { + if(electron){ + electron.app.exit() + } +}) \ No newline at end of file diff --git a/discord.png b/discord.png new file mode 100644 index 0000000..5c5bab0 Binary files /dev/null and b/discord.png differ diff --git a/modules/discord_cloudsync/discord_cloudsync.node b/modules/discord_cloudsync/discord_cloudsync.node new file mode 100644 index 0000000..b9bde66 Binary files /dev/null and b/modules/discord_cloudsync/discord_cloudsync.node differ diff --git a/modules/discord_cloudsync/index.js b/modules/discord_cloudsync/index.js new file mode 100644 index 0000000..af7f1c1 --- /dev/null +++ b/modules/discord_cloudsync/index.js @@ -0,0 +1,28 @@ +const EventEmitter = require('events'); +const {CloudSync: CloudSyncNative} = require('./discord_cloudsync.node'); + +function makeCallback(resolve, reject) { + return (err, result) => { + if (err != null && err !== '') { + reject(new Error(JSON.parse(err))); + } else { + resolve(result != null && result !== '' ? JSON.parse(result) : null); + } + }; +} + +class CloudSync extends EventEmitter { + constructor() { + super(); + + this._cloudSync = new CloudSyncNative(state => this.emit('state', JSON.parse(state))); + } + + sync(id, config) { + return new Promise((resolve, reject) => + this._cloudSync.command(JSON.stringify({type: 'SYNC', id, config}), makeCallback(resolve, reject)) + ); + } +} + +module.exports = CloudSync; diff --git a/modules/discord_cloudsync/manifest.json b/modules/discord_cloudsync/manifest.json new file mode 100644 index 0000000..d3d1741 --- /dev/null +++ b/modules/discord_cloudsync/manifest.json @@ -0,0 +1,7 @@ +{ + "files": [ + "discord_cloudsync.node", + "index.js", + "manifest.json" + ] +} \ No newline at end of file diff --git a/modules/discord_desktop_core/core/app/BetterDiscord/Logger.js b/modules/discord_desktop_core/core/app/BetterDiscord/Logger.js new file mode 100644 index 0000000..bc904d6 --- /dev/null +++ b/modules/discord_desktop_core/core/app/BetterDiscord/Logger.js @@ -0,0 +1,19 @@ +const { EventEmitter } = require("events") + +class Logger extends EventEmitter{ + constructor(name){ + super() + this.name = name + this.on("log", data => { + let args = ["%c["+this.name+"]", "\n font-weight: bold;\n color: purple;\n", ...data] + console.log(...args) + }) + } + + log(...data){ + this.emit("log", data) + } +} + +module.exports = Logger +module.exports.default = Logger \ No newline at end of file diff --git a/modules/discord_desktop_core/core/app/BetterDiscord/ace.js b/modules/discord_desktop_core/core/app/BetterDiscord/ace.js new file mode 100644 index 0000000..e2bcc51 --- /dev/null +++ b/modules/discord_desktop_core/core/app/BetterDiscord/ace.js @@ -0,0 +1,11589 @@ +(function() { + function o(n) { + var i = e; + n && (e[n] || (e[n] = {}), i = e[n]); + if (!i.define || !i.define.packaged) t.original = i.define, i.define = t, i.define.packaged = !0; + if (!i.requireAce || !i.requireAce.packaged) r.original = i.requireAce, i.requireAce = r, i.requireAce.packaged = !0 + } + var ACE_NAMESPACE = "", + e = function() { + return this + }(); + !e && typeof window != "undefined" && (e = window); + if (!ACE_NAMESPACE && typeof requirejs != "undefined") return; + var t = function(e, n, r) { + if (typeof e != "string") { + t.original ? t.original.apply(this, arguments) : (console.error("dropping module because define wasn't a string."), console.trace()); + return + } + arguments.length == 2 && (r = n), t.modules[e] || (t.payloads[e] = r, t.modules[e] = null) + }; + t.modules = {}, t.payloads = {}; + var n = function(e, t, n) { + if (typeof t == "string") { + var i = s(e, t); + if (i != undefined) return n && n(), i + } else if (Object.prototype.toString.call(t) === "[object Array]") { + var o = []; + for (var u = 0, a = t.length; u < a; ++u) { + var f = s(e, t[u]); + if (f == undefined && r.original) return; + o.push(f) + } + return n && n.apply(null, o) || !0 + } + }, + r = function(e, t) { + var i = n("", e, t); + return i == undefined && r.original ? r.original.apply(this, arguments) : i + }, + i = function(e, t) { + if (t.indexOf("!") !== -1) { + var n = t.split("!"); + return i(e, n[0]) + "!" + i(e, n[1]) + } + if (t.charAt(0) == ".") { + var r = e.split("/").slice(0, -1).join("/"); + t = r + "/" + t; + while (t.indexOf(".") !== -1 && s != t) { + var s = t; + t = t.replace(/\/\.\//, "/").replace(/[^\/]+\/\.\.\//, "") + } + } + return t + }, + s = function(e, r) { + r = i(e, r); + var s = t.modules[r]; + if (!s) { + s = t.payloads[r]; + if (typeof s == "function") { + var o = {}, + u = { + id: r, + uri: "", + exports: o, + packaged: !0 + }, + a = function(e, t) { + return n(r, e, t) + }, + f = s(a, o, u); + o = f || u.exports, t.modules[r] = o, delete t.payloads[r] + } + s = t.modules[r] = o || s + } + return s + }; + o(ACE_NAMESPACE) +})(), define("ace/lib/regexp", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + + function o(e) { + return (e.global ? "g" : "") + (e.ignoreCase ? "i" : "") + (e.multiline ? "m" : "") + (e.extended ? "x" : "") + (e.sticky ? "y" : "") + } + + function u(e, t, n) { + if (Array.prototype.indexOf) return e.indexOf(t, n); + for (var r = n || 0; r < e.length; r++) + if (e[r] === t) return r; + return -1 + } + var r = { + exec: RegExp.prototype.exec, + test: RegExp.prototype.test, + match: String.prototype.match, + replace: String.prototype.replace, + split: String.prototype.split + }, + i = r.exec.call(/()??/, "")[1] === undefined, + s = function() { + var e = /^/g; + return r.test.call(e, ""), !e.lastIndex + }(); + if (s && i) return; + RegExp.prototype.exec = function(e) { + var t = r.exec.apply(this, arguments), + n, a; + if (typeof e == "string" && t) { + !i && t.length > 1 && u(t, "") > -1 && (a = RegExp(this.source, r.replace.call(o(this), "g", "")), r.replace.call(e.slice(t.index), a, function() { + for (var e = 1; e < arguments.length - 2; e++) arguments[e] === undefined && (t[e] = undefined) + })); + if (this._xregexp && this._xregexp.captureNames) + for (var f = 1; f < t.length; f++) n = this._xregexp.captureNames[f - 1], n && (t[n] = t[f]); + !s && this.global && !t[0].length && this.lastIndex > t.index && this.lastIndex-- + } + return t + }, s || (RegExp.prototype.test = function(e) { + var t = r.exec.call(this, e); + return t && this.global && !t[0].length && this.lastIndex > t.index && this.lastIndex--, !!t + }) +}), define("ace/lib/es5-shim", ["require", "exports", "module"], function(e, t, n) { + function r() {} + + function w(e) { + try { + return Object.defineProperty(e, "sentinel", {}), "sentinel" in e + } catch (t) {} + } + + function H(e) { + return e = +e, e !== e ? e = 0 : e !== 0 && e !== 1 / 0 && e !== -1 / 0 && (e = (e > 0 || -1) * Math.floor(Math.abs(e))), e + } + + function B(e) { + var t = typeof e; + return e === null || t === "undefined" || t === "boolean" || t === "number" || t === "string" + } + + function j(e) { + var t, n, r; + if (B(e)) return e; + n = e.valueOf; + if (typeof n == "function") { + t = n.call(e); + if (B(t)) return t + } + r = e.toString; + if (typeof r == "function") { + t = r.call(e); + if (B(t)) return t + } + throw new TypeError + } + Function.prototype.bind || (Function.prototype.bind = function(t) { + var n = this; + if (typeof n != "function") throw new TypeError("Function.prototype.bind called on incompatible " + n); + var i = u.call(arguments, 1), + s = function() { + if (this instanceof s) { + var e = n.apply(this, i.concat(u.call(arguments))); + return Object(e) === e ? e : this + } + return n.apply(t, i.concat(u.call(arguments))) + }; + return n.prototype && (r.prototype = n.prototype, s.prototype = new r, r.prototype = null), s + }); + var i = Function.prototype.call, + s = Array.prototype, + o = Object.prototype, + u = s.slice, + a = i.bind(o.toString), + f = i.bind(o.hasOwnProperty), + l, c, h, p, d; + if (d = f(o, "__defineGetter__")) l = i.bind(o.__defineGetter__), c = i.bind(o.__defineSetter__), h = i.bind(o.__lookupGetter__), p = i.bind(o.__lookupSetter__); + if ([1, 2].splice(0).length != 2) + if (! function() { + function e(e) { + var t = new Array(e + 2); + return t[0] = t[1] = 0, t + } + var t = [], + n; + t.splice.apply(t, e(20)), t.splice.apply(t, e(26)), n = t.length, t.splice(5, 0, "XXX"), n + 1 == t.length; + if (n + 1 == t.length) return !0 + }()) Array.prototype.splice = function(e, t) { + var n = this.length; + e > 0 ? e > n && (e = n) : e == void 0 ? e = 0 : e < 0 && (e = Math.max(n + e, 0)), e + t < n || (t = n - e); + var r = this.slice(e, e + t), + i = u.call(arguments, 2), + s = i.length; + if (e === n) s && this.push.apply(this, i); + else { + var o = Math.min(t, n - e), + a = e + o, + f = a + s - o, + l = n - a, + c = n - o; + if (f < a) + for (var h = 0; h < l; ++h) this[f + h] = this[a + h]; + else if (f > a) + for (h = l; h--;) this[f + h] = this[a + h]; + if (s && e === c) this.length = c, this.push.apply(this, i); + else { + this.length = c + s; + for (h = 0; h < s; ++h) this[e + h] = i[h] + } + } + return r + }; + else { + var v = Array.prototype.splice; + Array.prototype.splice = function(e, t) { + return arguments.length ? v.apply(this, [e === void 0 ? 0 : e, t === void 0 ? this.length - e : t].concat(u.call(arguments, 2))) : [] + } + } Array.isArray || (Array.isArray = function(t) { + return a(t) == "[object Array]" + }); + var m = Object("a"), + g = m[0] != "a" || !(0 in m); + Array.prototype.forEach || (Array.prototype.forEach = function(t) { + var n = F(this), + r = g && a(this) == "[object String]" ? this.split("") : n, + i = arguments[1], + s = -1, + o = r.length >>> 0; + if (a(t) != "[object Function]") throw new TypeError; + while (++s < o) s in r && t.call(i, r[s], s, n) + }), Array.prototype.map || (Array.prototype.map = function(t) { + var n = F(this), + r = g && a(this) == "[object String]" ? this.split("") : n, + i = r.length >>> 0, + s = Array(i), + o = arguments[1]; + if (a(t) != "[object Function]") throw new TypeError(t + " is not a function"); + for (var u = 0; u < i; u++) u in r && (s[u] = t.call(o, r[u], u, n)); + return s + }), Array.prototype.filter || (Array.prototype.filter = function(t) { + var n = F(this), + r = g && a(this) == "[object String]" ? this.split("") : n, + i = r.length >>> 0, + s = [], + o, u = arguments[1]; + if (a(t) != "[object Function]") throw new TypeError(t + " is not a function"); + for (var f = 0; f < i; f++) f in r && (o = r[f], t.call(u, o, f, n) && s.push(o)); + return s + }), Array.prototype.every || (Array.prototype.every = function(t) { + var n = F(this), + r = g && a(this) == "[object String]" ? this.split("") : n, + i = r.length >>> 0, + s = arguments[1]; + if (a(t) != "[object Function]") throw new TypeError(t + " is not a function"); + for (var o = 0; o < i; o++) + if (o in r && !t.call(s, r[o], o, n)) return !1; + return !0 + }), Array.prototype.some || (Array.prototype.some = function(t) { + var n = F(this), + r = g && a(this) == "[object String]" ? this.split("") : n, + i = r.length >>> 0, + s = arguments[1]; + if (a(t) != "[object Function]") throw new TypeError(t + " is not a function"); + for (var o = 0; o < i; o++) + if (o in r && t.call(s, r[o], o, n)) return !0; + return !1 + }), Array.prototype.reduce || (Array.prototype.reduce = function(t) { + var n = F(this), + r = g && a(this) == "[object String]" ? this.split("") : n, + i = r.length >>> 0; + if (a(t) != "[object Function]") throw new TypeError(t + " is not a function"); + if (!i && arguments.length == 1) throw new TypeError("reduce of empty array with no initial value"); + var s = 0, + o; + if (arguments.length >= 2) o = arguments[1]; + else + do { + if (s in r) { + o = r[s++]; + break + } + if (++s >= i) throw new TypeError("reduce of empty array with no initial value") + } while (!0); + for (; s < i; s++) s in r && (o = t.call(void 0, o, r[s], s, n)); + return o + }), Array.prototype.reduceRight || (Array.prototype.reduceRight = function(t) { + var n = F(this), + r = g && a(this) == "[object String]" ? this.split("") : n, + i = r.length >>> 0; + if (a(t) != "[object Function]") throw new TypeError(t + " is not a function"); + if (!i && arguments.length == 1) throw new TypeError("reduceRight of empty array with no initial value"); + var s, o = i - 1; + if (arguments.length >= 2) s = arguments[1]; + else + do { + if (o in r) { + s = r[o--]; + break + } + if (--o < 0) throw new TypeError("reduceRight of empty array with no initial value") + } while (!0); + do o in this && (s = t.call(void 0, s, r[o], o, n)); while (o--); + return s + }); + if (!Array.prototype.indexOf || [0, 1].indexOf(1, 2) != -1) Array.prototype.indexOf = function(t) { + var n = g && a(this) == "[object String]" ? this.split("") : F(this), + r = n.length >>> 0; + if (!r) return -1; + var i = 0; + arguments.length > 1 && (i = H(arguments[1])), i = i >= 0 ? i : Math.max(0, r + i); + for (; i < r; i++) + if (i in n && n[i] === t) return i; + return -1 + }; + if (!Array.prototype.lastIndexOf || [0, 1].lastIndexOf(0, -3) != -1) Array.prototype.lastIndexOf = function(t) { + var n = g && a(this) == "[object String]" ? this.split("") : F(this), + r = n.length >>> 0; + if (!r) return -1; + var i = r - 1; + arguments.length > 1 && (i = Math.min(i, H(arguments[1]))), i = i >= 0 ? i : r - Math.abs(i); + for (; i >= 0; i--) + if (i in n && t === n[i]) return i; + return -1 + }; + Object.getPrototypeOf || (Object.getPrototypeOf = function(t) { + return t.__proto__ || (t.constructor ? t.constructor.prototype : o) + }); + if (!Object.getOwnPropertyDescriptor) { + var y = "Object.getOwnPropertyDescriptor called on a non-object: "; + Object.getOwnPropertyDescriptor = function(t, n) { + if (typeof t != "object" && typeof t != "function" || t === null) throw new TypeError(y + t); + if (!f(t, n)) return; + var r, i, s; + r = { + enumerable: !0, + configurable: !0 + }; + if (d) { + var u = t.__proto__; + t.__proto__ = o; + var i = h(t, n), + s = p(t, n); + t.__proto__ = u; + if (i || s) return i && (r.get = i), s && (r.set = s), r + } + return r.value = t[n], r + } + } + Object.getOwnPropertyNames || (Object.getOwnPropertyNames = function(t) { + return Object.keys(t) + }); + if (!Object.create) { + var b; + Object.prototype.__proto__ === null ? b = function() { + return { + __proto__: null + } + } : b = function() { + var e = {}; + for (var t in e) e[t] = null; + return e.constructor = e.hasOwnProperty = e.propertyIsEnumerable = e.isPrototypeOf = e.toLocaleString = e.toString = e.valueOf = e.__proto__ = null, e + }, Object.create = function(t, n) { + var r; + if (t === null) r = b(); + else { + if (typeof t != "object") throw new TypeError("typeof prototype[" + typeof t + "] != 'object'"); + var i = function() {}; + i.prototype = t, r = new i, r.__proto__ = t + } + return n !== void 0 && Object.defineProperties(r, n), r + } + } + if (Object.defineProperty) { + var E = w({}), + S = typeof document == "undefined" || w(document.createElement("div")); + if (!E || !S) var x = Object.defineProperty + } + if (!Object.defineProperty || x) { + var T = "Property description must be an object: ", + N = "Object.defineProperty called on non-object: ", + C = "getters & setters can not be defined on this javascript engine"; + Object.defineProperty = function(t, n, r) { + if (typeof t != "object" && typeof t != "function" || t === null) throw new TypeError(N + t); + if (typeof r != "object" && typeof r != "function" || r === null) throw new TypeError(T + r); + if (x) try { + return x.call(Object, t, n, r) + } catch (i) {} + if (f(r, "value")) + if (d && (h(t, n) || p(t, n))) { + var s = t.__proto__; + t.__proto__ = o, delete t[n], t[n] = r.value, t.__proto__ = s + } else t[n] = r.value; + else { + if (!d) throw new TypeError(C); + f(r, "get") && l(t, n, r.get), f(r, "set") && c(t, n, r.set) + } + return t + } + } + Object.defineProperties || (Object.defineProperties = function(t, n) { + for (var r in n) f(n, r) && Object.defineProperty(t, r, n[r]); + return t + }), Object.seal || (Object.seal = function(t) { + return t + }), Object.freeze || (Object.freeze = function(t) { + return t + }); + try { + Object.freeze(function() {}) + } catch (k) { + Object.freeze = function(t) { + return function(n) { + return typeof n == "function" ? n : t(n) + } + }(Object.freeze) + } + Object.preventExtensions || (Object.preventExtensions = function(t) { + return t + }), Object.isSealed || (Object.isSealed = function(t) { + return !1 + }), Object.isFrozen || (Object.isFrozen = function(t) { + return !1 + }), Object.isExtensible || (Object.isExtensible = function(t) { + if (Object(t) === t) throw new TypeError; + var n = ""; + while (f(t, n)) n += "?"; + t[n] = !0; + var r = f(t, n); + return delete t[n], r + }); + if (!Object.keys) { + var L = !0, + A = ["toString", "toLocaleString", "valueOf", "hasOwnProperty", "isPrototypeOf", "propertyIsEnumerable", "constructor"], + O = A.length; + for (var M in { + toString: null + }) L = !1; + Object.keys = function I(e) { + if (typeof e != "object" && typeof e != "function" || e === null) throw new TypeError("Object.keys called on a non-object"); + var I = []; + for (var t in e) f(e, t) && I.push(t); + if (L) + for (var n = 0, r = O; n < r; n++) { + var i = A[n]; + f(e, i) && I.push(i) + } + return I + } + } + Date.now || (Date.now = function() { + return (new Date).getTime() + }); + var _ = " \n \f\r \u00a0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029\ufeff"; + if (!String.prototype.trim || _.trim()) { + _ = "[" + _ + "]"; + var D = new RegExp("^" + _ + _ + "*"), + P = new RegExp(_ + _ + "*$"); + String.prototype.trim = function() { + return String(this).replace(D, "").replace(P, "") + } + } + var F = function(e) { + if (e == null) throw new TypeError("can't convert " + e + " to object"); + return Object(e) + } +}), define("ace/lib/fixoldbrowsers", ["require", "exports", "module", "ace/lib/regexp", "ace/lib/es5-shim"], function(e, t, n) { + "use strict"; + e("./regexp"), e("./es5-shim") +}), define("ace/lib/dom", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + var r = "http://www.w3.org/1999/xhtml"; + t.getDocumentHead = function(e) { + return e || (e = document), e.head || e.getElementsByTagName("head")[0] || e.documentElement + }, t.createElement = function(e, t) { + return document.createElementNS ? document.createElementNS(t || r, e) : document.createElement(e) + }, t.hasCssClass = function(e, t) { + var n = (e.className + "").split(/\s+/g); + return n.indexOf(t) !== -1 + }, t.addCssClass = function(e, n) { + t.hasCssClass(e, n) || (e.className += " " + n) + }, t.removeCssClass = function(e, t) { + var n = e.className.split(/\s+/g); + for (;;) { + var r = n.indexOf(t); + if (r == -1) break; + n.splice(r, 1) + } + e.className = n.join(" ") + }, t.toggleCssClass = function(e, t) { + var n = e.className.split(/\s+/g), + r = !0; + for (;;) { + var i = n.indexOf(t); + if (i == -1) break; + r = !1, n.splice(i, 1) + } + return r && n.push(t), e.className = n.join(" "), r + }, t.setCssClass = function(e, n, r) { + r ? t.addCssClass(e, n) : t.removeCssClass(e, n) + }, t.hasCssString = function(e, t) { + var n = 0, + r; + t = t || document; + if (t.createStyleSheet && (r = t.styleSheets)) { + while (n < r.length) + if (r[n++].owningElement.id === e) return !0 + } else if (r = t.getElementsByTagName("style")) + while (n < r.length) + if (r[n++].id === e) return !0; + return !1 + }, t.importCssString = function(n, r, i) { + i = i || document; + if (r && t.hasCssString(r, i)) return null; + var s; + r && (n += "\n/*# sourceURL=ace/css/" + r + " */"), i.createStyleSheet ? (s = i.createStyleSheet(), s.cssText = n, r && (s.owningElement.id = r)) : (s = t.createElement("style"), s.appendChild(i.createTextNode(n)), r && (s.id = r), t.getDocumentHead(i).appendChild(s)) + }, t.importCssStylsheet = function(e, n) { + if (n.createStyleSheet) n.createStyleSheet(e); + else { + var r = t.createElement("link"); + r.rel = "stylesheet", r.href = e, t.getDocumentHead(n).appendChild(r) + } + }, t.getInnerWidth = function(e) { + return parseInt(t.computedStyle(e, "paddingLeft"), 10) + parseInt(t.computedStyle(e, "paddingRight"), 10) + e.clientWidth + }, t.getInnerHeight = function(e) { + return parseInt(t.computedStyle(e, "paddingTop"), 10) + parseInt(t.computedStyle(e, "paddingBottom"), 10) + e.clientHeight + }, t.scrollbarWidth = function(e) { + var n = t.createElement("ace_inner"); + n.style.width = "100%", n.style.minWidth = "0px", n.style.height = "200px", n.style.display = "block"; + var r = t.createElement("ace_outer"), + i = r.style; + i.position = "absolute", i.left = "-10000px", i.overflow = "hidden", i.width = "200px", i.minWidth = "0px", i.height = "150px", i.display = "block", r.appendChild(n); + var s = e.documentElement; + s.appendChild(r); + var o = n.offsetWidth; + i.overflow = "scroll"; + var u = n.offsetWidth; + return o == u && (u = r.clientWidth), s.removeChild(r), o - u + }; + if (typeof document == "undefined") { + t.importCssString = function() {}; + return + } + window.pageYOffset !== undefined ? (t.getPageScrollTop = function() { + return window.pageYOffset + }, t.getPageScrollLeft = function() { + return window.pageXOffset + }) : (t.getPageScrollTop = function() { + return document.body.scrollTop + }, t.getPageScrollLeft = function() { + return document.body.scrollLeft + }), window.getComputedStyle ? t.computedStyle = function(e, t) { + return t ? (window.getComputedStyle(e, "") || {})[t] || "" : window.getComputedStyle(e, "") || {} + } : t.computedStyle = function(e, t) { + return t ? e.currentStyle[t] : e.currentStyle + }, t.setInnerHtml = function(e, t) { + var n = e.cloneNode(!1); + return n.innerHTML = t, e.parentNode.replaceChild(n, e), n + }, "textContent" in document.documentElement ? (t.setInnerText = function(e, t) { + e.textContent = t + }, t.getInnerText = function(e) { + return e.textContent + }) : (t.setInnerText = function(e, t) { + e.innerText = t + }, t.getInnerText = function(e) { + return e.innerText + }), t.getParentWindow = function(e) { + return e.defaultView || e.parentWindow + } +}), define("ace/lib/oop", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + t.inherits = function(e, t) { + e.super_ = t, e.prototype = Object.create(t.prototype, { + constructor: { + value: e, + enumerable: !1, + writable: !0, + configurable: !0 + } + }) + }, t.mixin = function(e, t) { + for (var n in t) e[n] = t[n]; + return e + }, t.implement = function(e, n) { + t.mixin(e, n) + } +}), define("ace/lib/keys", ["require", "exports", "module", "ace/lib/fixoldbrowsers", "ace/lib/oop"], function(e, t, n) { + "use strict"; + e("./fixoldbrowsers"); + var r = e("./oop"), + i = function() { + var e = { + MODIFIER_KEYS: { + 16: "Shift", + 17: "Ctrl", + 18: "Alt", + 224: "Meta" + }, + KEY_MODS: { + ctrl: 1, + alt: 2, + option: 2, + shift: 4, + "super": 8, + meta: 8, + command: 8, + cmd: 8 + }, + FUNCTION_KEYS: { + 8: "Backspace", + 9: "Tab", + 13: "Return", + 19: "Pause", + 27: "Esc", + 32: "Space", + 33: "PageUp", + 34: "PageDown", + 35: "End", + 36: "Home", + 37: "Left", + 38: "Up", + 39: "Right", + 40: "Down", + 44: "Print", + 45: "Insert", + 46: "Delete", + 96: "Numpad0", + 97: "Numpad1", + 98: "Numpad2", + 99: "Numpad3", + 100: "Numpad4", + 101: "Numpad5", + 102: "Numpad6", + 103: "Numpad7", + 104: "Numpad8", + 105: "Numpad9", + "-13": "NumpadEnter", + 112: "F1", + 113: "F2", + 114: "F3", + 115: "F4", + 116: "F5", + 117: "F6", + 118: "F7", + 119: "F8", + 120: "F9", + 121: "F10", + 122: "F11", + 123: "F12", + 144: "Numlock", + 145: "Scrolllock" + }, + PRINTABLE_KEYS: { + 32: " ", + 48: "0", + 49: "1", + 50: "2", + 51: "3", + 52: "4", + 53: "5", + 54: "6", + 55: "7", + 56: "8", + 57: "9", + 59: ";", + 61: "=", + 65: "a", + 66: "b", + 67: "c", + 68: "d", + 69: "e", + 70: "f", + 71: "g", + 72: "h", + 73: "i", + 74: "j", + 75: "k", + 76: "l", + 77: "m", + 78: "n", + 79: "o", + 80: "p", + 81: "q", + 82: "r", + 83: "s", + 84: "t", + 85: "u", + 86: "v", + 87: "w", + 88: "x", + 89: "y", + 90: "z", + 107: "+", + 109: "-", + 110: ".", + 186: ";", + 187: "=", + 188: ",", + 189: "-", + 190: ".", + 191: "/", + 192: "`", + 219: "[", + 220: "\\", + 221: "]", + 222: "'", + 111: "/", + 106: "*" + } + }, + t, n; + for (n in e.FUNCTION_KEYS) t = e.FUNCTION_KEYS[n].toLowerCase(), e[t] = parseInt(n, 10); + for (n in e.PRINTABLE_KEYS) t = e.PRINTABLE_KEYS[n].toLowerCase(), e[t] = parseInt(n, 10); + return r.mixin(e, e.MODIFIER_KEYS), r.mixin(e, e.PRINTABLE_KEYS), r.mixin(e, e.FUNCTION_KEYS), e.enter = e["return"], e.escape = e.esc, e.del = e["delete"], e[173] = "-", + function() { + var t = ["cmd", "ctrl", "alt", "shift"]; + for (var n = Math.pow(2, t.length); n--;) e.KEY_MODS[n] = t.filter(function(t) { + return n & e.KEY_MODS[t] + }).join("-") + "-" + }(), e.KEY_MODS[0] = "", e.KEY_MODS[-1] = "input-", e + }(); + r.mixin(t, i), t.keyCodeToString = function(e) { + var t = i[e]; + return typeof t != "string" && (t = String.fromCharCode(e)), t.toLowerCase() + } +}), define("ace/lib/useragent", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + t.OS = { + LINUX: "LINUX", + MAC: "MAC", + WINDOWS: "WINDOWS" + }, t.getOS = function() { + return t.isMac ? t.OS.MAC : t.isLinux ? t.OS.LINUX : t.OS.WINDOWS + }; + if (typeof navigator != "object") return; + var r = (navigator.platform.match(/mac|win|linux/i) || ["other"])[0].toLowerCase(), + i = navigator.userAgent; + t.isWin = r == "win", t.isMac = r == "mac", t.isLinux = r == "linux", t.isIE = navigator.appName == "Microsoft Internet Explorer" || navigator.appName.indexOf("MSAppHost") >= 0 ? parseFloat((i.match(/(?:MSIE |Trident\/[0-9]+[\.0-9]+;.*rv:)([0-9]+[\.0-9]+)/) || [])[1]) : parseFloat((i.match(/(?:Trident\/[0-9]+[\.0-9]+;.*rv:)([0-9]+[\.0-9]+)/) || [])[1]), t.isOldIE = t.isIE && t.isIE < 9, t.isGecko = t.isMozilla = (window.Controllers || window.controllers) && window.navigator.product === "Gecko", t.isOldGecko = t.isGecko && parseInt((i.match(/rv:(\d+)/) || [])[1], 10) < 4, t.isOpera = window.opera && Object.prototype.toString.call(window.opera) == "[object Opera]", t.isWebKit = parseFloat(i.split("WebKit/")[1]) || undefined, t.isChrome = parseFloat(i.split(" Chrome/")[1]) || undefined, t.isAIR = i.indexOf("AdobeAIR") >= 0, t.isIPad = i.indexOf("iPad") >= 0, t.isChromeOS = i.indexOf(" CrOS ") >= 0, t.isIOS = /iPad|iPhone|iPod/.test(i) && !window.MSStream, t.isIOS && (t.isMac = !0) +}), define("ace/lib/event", ["require", "exports", "module", "ace/lib/keys", "ace/lib/useragent"], function(e, t, n) { + "use strict"; + + function a(e, t, n) { + var a = u(t); + if (!i.isMac && s) { + t.getModifierState && (t.getModifierState("OS") || t.getModifierState("Win")) && (a |= 8); + if (s.altGr) { + if ((3 & a) == 3) return; + s.altGr = 0 + } + if (n === 18 || n === 17) { + var f = "location" in t ? t.location : t.keyLocation; + if (n === 17 && f === 1) s[n] == 1 && (o = t.timeStamp); + else if (n === 18 && a === 3 && f === 2) { + var l = t.timeStamp - o; + l < 50 && (s.altGr = !0) + } + } + } + n in r.MODIFIER_KEYS && (n = -1), a & 8 && n >= 91 && n <= 93 && (n = -1); + if (!a && n === 13) { + var f = "location" in t ? t.location : t.keyLocation; + if (f === 3) { + e(t, a, -n); + if (t.defaultPrevented) return + } + } + if (i.isChromeOS && a & 8) { + e(t, a, n); + if (t.defaultPrevented) return; + a &= -9 + } + return !!a || n in r.FUNCTION_KEYS || n in r.PRINTABLE_KEYS ? e(t, a, n) : !1 + } + + function f() { + s = Object.create(null) + } + var r = e("./keys"), + i = e("./useragent"), + s = null, + o = 0; + t.addListener = function(e, t, n) { + if (e.addEventListener) return e.addEventListener(t, n, !1); + if (e.attachEvent) { + var r = function() { + n.call(e, window.event) + }; + n._wrapper = r, e.attachEvent("on" + t, r) + } + }, t.removeListener = function(e, t, n) { + if (e.removeEventListener) return e.removeEventListener(t, n, !1); + e.detachEvent && e.detachEvent("on" + t, n._wrapper || n) + }, t.stopEvent = function(e) { + return t.stopPropagation(e), t.preventDefault(e), !1 + }, t.stopPropagation = function(e) { + e.stopPropagation ? e.stopPropagation() : e.cancelBubble = !0 + }, t.preventDefault = function(e) { + e.preventDefault ? e.preventDefault() : e.returnValue = !1 + }, t.getButton = function(e) { + return e.type == "dblclick" ? 0 : e.type == "contextmenu" || i.isMac && e.ctrlKey && !e.altKey && !e.shiftKey ? 2 : e.preventDefault ? e.button : { + 1: 0, + 2: 2, + 4: 1 + } [e.button] + }, t.capture = function(e, n, r) { + function i(e) { + n && n(e), r && r(e), t.removeListener(document, "mousemove", n, !0), t.removeListener(document, "mouseup", i, !0), t.removeListener(document, "dragstart", i, !0) + } + return t.addListener(document, "mousemove", n, !0), t.addListener(document, "mouseup", i, !0), t.addListener(document, "dragstart", i, !0), i + }, t.addTouchMoveListener = function(e, n) { + var r, i; + t.addListener(e, "touchstart", function(e) { + var t = e.touches, + n = t[0]; + r = n.clientX, i = n.clientY + }), t.addListener(e, "touchmove", function(e) { + var t = e.touches; + if (t.length > 1) return; + var s = t[0]; + e.wheelX = r - s.clientX, e.wheelY = i - s.clientY, r = s.clientX, i = s.clientY, n(e) + }) + }, t.addMouseWheelListener = function(e, n) { + "onmousewheel" in e ? t.addListener(e, "mousewheel", function(e) { + var t = 8; + e.wheelDeltaX !== undefined ? (e.wheelX = -e.wheelDeltaX / t, e.wheelY = -e.wheelDeltaY / t) : (e.wheelX = 0, e.wheelY = -e.wheelDelta / t), n(e) + }) : "onwheel" in e ? t.addListener(e, "wheel", function(e) { + var t = .35; + switch (e.deltaMode) { + case e.DOM_DELTA_PIXEL: + e.wheelX = e.deltaX * t || 0, e.wheelY = e.deltaY * t || 0; + break; + case e.DOM_DELTA_LINE: + case e.DOM_DELTA_PAGE: + e.wheelX = (e.deltaX || 0) * 5, e.wheelY = (e.deltaY || 0) * 5 + } + n(e) + }) : t.addListener(e, "DOMMouseScroll", function(e) { + e.axis && e.axis == e.HORIZONTAL_AXIS ? (e.wheelX = (e.detail || 0) * 5, e.wheelY = 0) : (e.wheelX = 0, e.wheelY = (e.detail || 0) * 5), n(e) + }) + }, t.addMultiMouseDownListener = function(e, n, r, s) { + function c(e) { + t.getButton(e) !== 0 ? o = 0 : e.detail > 1 ? (o++, o > 4 && (o = 1)) : o = 1; + if (i.isIE) { + var c = Math.abs(e.clientX - u) > 5 || Math.abs(e.clientY - a) > 5; + if (!f || c) o = 1; + f && clearTimeout(f), f = setTimeout(function() { + f = null + }, n[o - 1] || 600), o == 1 && (u = e.clientX, a = e.clientY) + } + e._clicks = o, r[s]("mousedown", e); + if (o > 4) o = 0; + else if (o > 1) return r[s](l[o], e) + } + + function h(e) { + o = 2, f && clearTimeout(f), f = setTimeout(function() { + f = null + }, n[o - 1] || 600), r[s]("mousedown", e), r[s](l[o], e) + } + var o = 0, + u, a, f, l = { + 2: "dblclick", + 3: "tripleclick", + 4: "quadclick" + }; + Array.isArray(e) || (e = [e]), e.forEach(function(e) { + t.addListener(e, "mousedown", c), i.isOldIE && t.addListener(e, "dblclick", h) + }) + }; + var u = !i.isMac || !i.isOpera || "KeyboardEvent" in window ? function(e) { + return 0 | (e.ctrlKey ? 1 : 0) | (e.altKey ? 2 : 0) | (e.shiftKey ? 4 : 0) | (e.metaKey ? 8 : 0) + } : function(e) { + return 0 | (e.metaKey ? 1 : 0) | (e.altKey ? 2 : 0) | (e.shiftKey ? 4 : 0) | (e.ctrlKey ? 8 : 0) + }; + t.getModifierString = function(e) { + return r.KEY_MODS[u(e)] + }, t.addCommandKeyListener = function(e, n) { + var r = t.addListener; + if (i.isOldGecko || i.isOpera && !("KeyboardEvent" in window)) { + var o = null; + r(e, "keydown", function(e) { + o = e.keyCode + }), r(e, "keypress", function(e) { + return a(n, e, o) + }) + } else { + var u = null; + r(e, "keydown", function(e) { + s[e.keyCode] = (s[e.keyCode] || 0) + 1; + var t = a(n, e, e.keyCode); + return u = e.defaultPrevented, t + }), r(e, "keypress", function(e) { + u && (e.ctrlKey || e.altKey || e.shiftKey || e.metaKey) && (t.stopEvent(e), u = null) + }), r(e, "keyup", function(e) { + s[e.keyCode] = null + }), s || (f(), r(window, "focus", f)) + } + }; + if (typeof window == "object" && window.postMessage && !i.isOldIE) { + var l = 1; + t.nextTick = function(e, n) { + n = n || window; + var r = "zero-timeout-message-" + l; + t.addListener(n, "message", function i(s) { + s.data == r && (t.stopPropagation(s), t.removeListener(n, "message", i), e()) + }), n.postMessage(r, "*") + } + } + t.nextFrame = typeof window == "object" && (window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || window.msRequestAnimationFrame || window.oRequestAnimationFrame), t.nextFrame ? t.nextFrame = t.nextFrame.bind(window) : t.nextFrame = function(e) { + setTimeout(e, 17) + } +}), define("ace/lib/lang", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + t.last = function(e) { + return e[e.length - 1] + }, t.stringReverse = function(e) { + return e.split("").reverse().join("") + }, t.stringRepeat = function(e, t) { + var n = ""; + while (t > 0) { + t & 1 && (n += e); + if (t >>= 1) e += e + } + return n + }; + var r = /^\s\s*/, + i = /\s\s*$/; + t.stringTrimLeft = function(e) { + return e.replace(r, "") + }, t.stringTrimRight = function(e) { + return e.replace(i, "") + }, t.copyObject = function(e) { + var t = {}; + for (var n in e) t[n] = e[n]; + return t + }, t.copyArray = function(e) { + var t = []; + for (var n = 0, r = e.length; n < r; n++) e[n] && typeof e[n] == "object" ? t[n] = this.copyObject(e[n]) : t[n] = e[n]; + return t + }, t.deepCopy = function s(e) { + if (typeof e != "object" || !e) return e; + var t; + if (Array.isArray(e)) { + t = []; + for (var n = 0; n < e.length; n++) t[n] = s(e[n]); + return t + } + if (Object.prototype.toString.call(e) !== "[object Object]") return e; + t = {}; + for (var n in e) t[n] = s(e[n]); + return t + }, t.arrayToMap = function(e) { + var t = {}; + for (var n = 0; n < e.length; n++) t[e[n]] = 1; + return t + }, t.createMap = function(e) { + var t = Object.create(null); + for (var n in e) t[n] = e[n]; + return t + }, t.arrayRemove = function(e, t) { + for (var n = 0; n <= e.length; n++) t === e[n] && e.splice(n, 1) + }, t.escapeRegExp = function(e) { + return e.replace(/([.*+?^${}()|[\]\/\\])/g, "\\$1") + }, t.escapeHTML = function(e) { + return e.replace(/&/g, "&").replace(/"/g, """).replace(/'/g, "'").replace(/ h.length ? e = e.substr(9) : e.substr(0, 4) == h.substr(0, 4) ? e = e.substr(4, e.length - h.length + 1) : e.charAt(e.length - 1) == h.charAt(0) && (e = e.slice(0, -1)), e != h.charAt(0) && e.charAt(e.length - 1) == h.charAt(0) && (e = e.slice(0, -1)), e && t.onTextInput(e)), p && (p = !1), L && (L = !1) + }, + O = function(e) { + if (m) return; + var t = c.value; + A(t), T() + }, + M = function(e, t, n) { + var r = e.clipboardData || window.clipboardData; + if (!r || f) return; + var i = l || n ? "Text" : "text/plain"; + try { + return t ? r.setData(i, t) !== !1 : r.getData(i) + } catch (e) { + if (!n) return M(e, t, !0) + } + }, + _ = function(e, n) { + var s = t.getCopyText(); + if (!s) return r.preventDefault(e); + M(e, s) ? (i.isIOS && (d = n, c.value = "\n aa" + s + "a a\n", c.setSelectionRange(4, 4 + s.length), p = { + value: s + }), n ? t.onCut() : t.onCopy(), i.isIOS || r.preventDefault(e)) : (p = !0, c.value = s, c.select(), setTimeout(function() { + p = !1, T(), x(), n ? t.onCut() : t.onCopy() + })) + }, + D = function(e) { + _(e, !0) + }, + P = function(e) { + _(e, !1) + }, + H = function(e) { + var n = M(e); + typeof n == "string" ? (n && t.onPaste(n, e), i.isIE && setTimeout(x), r.preventDefault(e)) : (c.value = "", v = !0) + }; + r.addCommandKeyListener(c, t.onCommandKey.bind(t)), r.addListener(c, "select", C), r.addListener(c, "input", O), r.addListener(c, "cut", D), r.addListener(c, "copy", P), r.addListener(c, "paste", H); + var B = function(e) { + if (m || !t.onCompositionStart || t.$readOnly) return; + m = {}, m.canUndo = t.session.$undoManager, t.onCompositionStart(), setTimeout(j, 0), t.on("mousedown", F), m.canUndo && !t.selection.isEmpty() && (t.insert(""), t.session.markUndoGroup(), t.selection.clearSelection()), t.session.markUndoGroup() + }, + j = function() { + if (!m || !t.onCompositionUpdate || t.$readOnly) return; + var e = c.value.replace(/\x01/g, ""); + if (m.lastValue === e) return; + t.onCompositionUpdate(e), m.lastValue && t.undo(), m.canUndo && (m.lastValue = e); + if (m.lastValue) { + var n = t.selection.getRange(); + t.insert(m.lastValue), t.session.markUndoGroup(), m.range = t.selection.getRange(), t.selection.setRange(n), t.selection.clearSelection() + } + }, + F = function(e) { + if (!t.onCompositionEnd || t.$readOnly) return; + var n = m; + m = !1; + var r = setTimeout(function() { + r = null; + var e = c.value.replace(/\x01/g, ""); + if (m) return; + e == n.lastValue ? T() : !n.lastValue && e && (T(), A(e)) + }); + k = function(i) { + return r && clearTimeout(r), i = i.replace(/\x01/g, ""), i == n.lastValue ? "" : (n.lastValue && r && t.undo(), i) + }, t.onCompositionEnd(), t.removeListener("mousedown", F), e.type == "compositionend" && n.range && t.selection.setRange(n.range); + var s = !!i.isChrome && i.isChrome >= 53 || !!i.isWebKit && i.isWebKit >= 603; + s && O() + }, + I = o.delayedCall(j, 50); + r.addListener(c, "compositionstart", B), i.isGecko ? r.addListener(c, "text", function() { + I.schedule() + }) : (r.addListener(c, "keyup", function() { + I.schedule() + }), r.addListener(c, "keydown", function() { + I.schedule() + })), r.addListener(c, "compositionend", F), this.getElement = function() { + return c + }, this.setReadOnly = function(e) { + c.readOnly = e + }, this.onContextMenu = function(e) { + L = !0, x(t.selection.isEmpty()), t._emit("nativecontextmenu", { + target: t, + domEvent: e + }), this.moveToMouse(e, !0) + }, this.moveToMouse = function(e, n) { + g || (g = c.style.cssText), c.style.cssText = (n ? "z-index:100000;" : "") + "height:" + c.style.height + ";" + (i.isIE ? "opacity:0.1;" : ""); + var o = t.container.getBoundingClientRect(), + u = s.computedStyle(t.container), + a = o.top + (parseInt(u.borderTopWidth) || 0), + f = o.left + (parseInt(o.borderLeftWidth) || 0), + l = o.bottom - a - c.clientHeight - 2, + h = function(e) { + c.style.left = e.clientX - f - 2 + "px", c.style.top = Math.min(e.clientY - a - 2, l) + "px" + }; + h(e); + if (e.type != "mousedown") return; + t.renderer.$keepTextAreaAtCursor && (t.renderer.$keepTextAreaAtCursor = null), clearTimeout(q), i.isWin && r.capture(t.container, h, R) + }, this.onContextMenuClose = R; + var q, U = function(e) { + t.textInput.onContextMenu(e), R() + }; + r.addListener(c, "mouseup", U), r.addListener(c, "mousedown", function(e) { + e.preventDefault(), R() + }), r.addListener(t.renderer.scroller, "contextmenu", U), r.addListener(c, "contextmenu", U); + if (i.isIOS) { + var z = null, + W = !1; + e.addEventListener("keydown", function(e) { + z && clearTimeout(z), W = !0 + }), e.addEventListener("keyup", function(e) { + z = setTimeout(function() { + W = !1 + }, 100) + }); + var X = function(e) { + if (document.activeElement !== c) return; + if (W) return; + if (d) return setTimeout(function() { + d = !1 + }, 100); + var n = c.selectionStart, + r = c.selectionEnd; + c.setSelectionRange(4, 5); + if (n == r) switch (n) { + case 0: + t.onCommandKey(null, 0, u.up); + break; + case 1: + t.onCommandKey(null, 0, u.home); + break; + case 2: + t.onCommandKey(null, a.option, u.left); + break; + case 4: + t.onCommandKey(null, 0, u.left); + break; + case 5: + t.onCommandKey(null, 0, u.right); + break; + case 7: + t.onCommandKey(null, a.option, u.right); + break; + case 8: + t.onCommandKey(null, 0, u.end); + break; + case 9: + t.onCommandKey(null, 0, u.down) + } else { + switch (r) { + case 6: + t.onCommandKey(null, a.shift, u.right); + break; + case 7: + t.onCommandKey(null, a.shift | a.option, u.right); + break; + case 8: + t.onCommandKey(null, a.shift, u.end); + break; + case 9: + t.onCommandKey(null, a.shift, u.down) + } + switch (n) { + case 0: + t.onCommandKey(null, a.shift, u.up); + break; + case 1: + t.onCommandKey(null, a.shift, u.home); + break; + case 2: + t.onCommandKey(null, a.shift | a.option, u.left); + break; + case 3: + t.onCommandKey(null, a.shift, u.left) + } + } + }; + document.addEventListener("selectionchange", X), t.on("destroy", function() { + document.removeEventListener("selectionchange", X) + }) + } + }; + t.TextInput = c +}), define("ace/keyboard/textinput", ["require", "exports", "module", "ace/lib/event", "ace/lib/useragent", "ace/lib/dom", "ace/lib/lang", "ace/keyboard/textinput_ios"], function(e, t, n) { + "use strict"; + var r = e("../lib/event"), + i = e("../lib/useragent"), + s = e("../lib/dom"), + o = e("../lib/lang"), + u = i.isChrome < 18, + a = i.isIE, + f = e("./textinput_ios").TextInput, + l = function(e, t) { + function w(e) { + if (p) return; + p = !0; + if (T) var t = 0, + r = e ? 0 : n.value.length - 1; + else var t = e ? 2 : 1, + r = 2; + try { + n.setSelectionRange(t, r) + } catch (i) {} + p = !1 + } + + function E() { + if (p) return; + n.value = l, i.isWebKit && b.schedule() + } + + function F() { + clearTimeout(j), j = setTimeout(function() { + d && (n.style.cssText = d, d = ""), t.renderer.$keepTextAreaAtCursor == null && (t.renderer.$keepTextAreaAtCursor = !0, t.renderer.$moveTextAreaToCursor()) + }, 0) + } + if (i.isIOS) return f.call(this, e, t); + var n = s.createElement("textarea"); + n.className = "ace_text-input", n.setAttribute("wrap", "off"), n.setAttribute("autocorrect", "off"), n.setAttribute("autocapitalize", "off"), n.setAttribute("spellcheck", !1), n.style.opacity = "0", e.insertBefore(n, e.firstChild); + var l = "\u2028\u2028", + c = !1, + h = !1, + p = !1, + d = "", + v = !0; + try { + var m = document.activeElement === n + } catch (g) {} + r.addListener(n, "blur", function(e) { + t.onBlur(e), m = !1 + }), r.addListener(n, "focus", function(e) { + m = !0, t.onFocus(e), w() + }), this.focus = function() { + if (d) return n.focus(); + var e = n.style.top; + n.style.position = "fixed", n.style.top = "0px", n.focus(), setTimeout(function() { + n.style.position = "", n.style.top == "0px" && (n.style.top = e) + }, 0) + }, this.blur = function() { + n.blur() + }, this.isFocused = function() { + return m + }; + var y = o.delayedCall(function() { + m && w(v) + }), + b = o.delayedCall(function() { + p || (n.value = l, m && w()) + }); + i.isWebKit || t.addEventListener("changeSelection", function() { + t.selection.isEmpty() != v && (v = !v, y.schedule()) + }), E(), m && t.onFocus(); + var S = function(e) { + return e.selectionStart === 0 && e.selectionEnd === e.value.length + }, + x = function(e) { + c ? c = !1 : S(n) ? (t.selectAll(), w()) : T && w(t.selection.isEmpty()) + }, + T = null; + this.setInputHandler = function(e) { + T = e + }, this.getInputHandler = function() { + return T + }; + var N = !1, + C = function(e) { + T && (e = T(e), T = null), h ? (w(), e && t.onPaste(e), h = !1) : e == l.charAt(0) ? N ? t.execCommand("del", { + source: "ace" + }) : t.execCommand("backspace", { + source: "ace" + }) : (e.substring(0, 2) == l ? e = e.substr(2) : e.charAt(0) == l.charAt(0) ? e = e.substr(1) : e.charAt(e.length - 1) == l.charAt(0) && (e = e.slice(0, -1)), e.charAt(e.length - 1) == l.charAt(0) && (e = e.slice(0, -1)), e && t.onTextInput(e)), N && (N = !1) + }, + k = function(e) { + if (p) return; + var t = n.value; + C(t), E() + }, + L = function(e, t, n) { + var r = e.clipboardData || window.clipboardData; + if (!r || u) return; + var i = a || n ? "Text" : "text/plain"; + try { + return t ? r.setData(i, t) !== !1 : r.getData(i) + } catch (e) { + if (!n) return L(e, t, !0) + } + }, + A = function(e, i) { + var s = t.getCopyText(); + if (!s) return r.preventDefault(e); + L(e, s) ? (i ? t.onCut() : t.onCopy(), r.preventDefault(e)) : (c = !0, n.value = s, n.select(), setTimeout(function() { + c = !1, E(), w(), i ? t.onCut() : t.onCopy() + })) + }, + O = function(e) { + A(e, !0) + }, + M = function(e) { + A(e, !1) + }, + _ = function(e) { + var s = L(e); + typeof s == "string" ? (s && t.onPaste(s, e), i.isIE && setTimeout(w), r.preventDefault(e)) : (n.value = "", h = !0) + }; + r.addCommandKeyListener(n, t.onCommandKey.bind(t)), r.addListener(n, "select", x), r.addListener(n, "input", k), r.addListener(n, "cut", O), r.addListener(n, "copy", M), r.addListener(n, "paste", _), (!("oncut" in n) || !("oncopy" in n) || !("onpaste" in n)) && r.addListener(e, "keydown", function(e) { + if (i.isMac && !e.metaKey || !e.ctrlKey) return; + switch (e.keyCode) { + case 67: + M(e); + break; + case 86: + _(e); + break; + case 88: + O(e) + } + }); + var D = function(e) { + if (p || !t.onCompositionStart || t.$readOnly) return; + p = {}, p.canUndo = t.session.$undoManager, t.onCompositionStart(), setTimeout(P, 0), t.on("mousedown", H), p.canUndo && !t.selection.isEmpty() && (t.insert(""), t.session.markUndoGroup(), t.selection.clearSelection()), t.session.markUndoGroup() + }, + P = function() { + if (!p || !t.onCompositionUpdate || t.$readOnly) return; + var e = n.value.replace(/\u2028/g, ""); + if (p.lastValue === e) return; + t.onCompositionUpdate(e), p.lastValue && t.undo(), p.canUndo && (p.lastValue = e); + if (p.lastValue) { + var r = t.selection.getRange(); + t.insert(p.lastValue), t.session.markUndoGroup(), p.range = t.selection.getRange(), t.selection.setRange(r), t.selection.clearSelection() + } + }, + H = function(e) { + if (!t.onCompositionEnd || t.$readOnly) return; + var r = p; + p = !1; + var s = setTimeout(function() { + s = null; + var e = n.value.replace(/\u2028/g, ""); + if (p) return; + e == r.lastValue ? E() : !r.lastValue && e && (E(), C(e)) + }); + T = function(n) { + return s && clearTimeout(s), n = n.replace(/\u2028/g, ""), n == r.lastValue ? "" : (r.lastValue && s && t.undo(), n) + }, t.onCompositionEnd(), t.removeListener("mousedown", H), e.type == "compositionend" && r.range && t.selection.setRange(r.range); + var o = !!i.isChrome && i.isChrome >= 53 || !!i.isWebKit && i.isWebKit >= 603; + o && k() + }, + B = o.delayedCall(P, 50); + r.addListener(n, "compositionstart", D), i.isGecko ? r.addListener(n, "text", function() { + B.schedule() + }) : (r.addListener(n, "keyup", function() { + B.schedule() + }), r.addListener(n, "keydown", function() { + B.schedule() + })), r.addListener(n, "compositionend", H), this.getElement = function() { + return n + }, this.setReadOnly = function(e) { + n.readOnly = e + }, this.onContextMenu = function(e) { + N = !0, w(t.selection.isEmpty()), t._emit("nativecontextmenu", { + target: t, + domEvent: e + }), this.moveToMouse(e, !0) + }, this.moveToMouse = function(e, o) { + d || (d = n.style.cssText), n.style.cssText = (o ? "z-index:100000;" : "") + "height:" + n.style.height + ";" + (i.isIE ? "opacity:0.1;" : ""); + var u = t.container.getBoundingClientRect(), + a = s.computedStyle(t.container), + f = u.top + (parseInt(a.borderTopWidth) || 0), + l = u.left + (parseInt(u.borderLeftWidth) || 0), + c = u.bottom - f - n.clientHeight - 2, + h = function(e) { + n.style.left = e.clientX - l - 2 + "px", n.style.top = Math.min(e.clientY - f - 2, c) + "px" + }; + h(e); + if (e.type != "mousedown") return; + t.renderer.$keepTextAreaAtCursor && (t.renderer.$keepTextAreaAtCursor = null), clearTimeout(j), i.isWin && r.capture(t.container, h, F) + }, this.onContextMenuClose = F; + var j, I = function(e) { + t.textInput.onContextMenu(e), F() + }; + r.addListener(n, "mouseup", I), r.addListener(n, "mousedown", function(e) { + e.preventDefault(), F() + }), r.addListener(t.renderer.scroller, "contextmenu", I), r.addListener(n, "contextmenu", I) + }; + t.TextInput = l +}), define("ace/mouse/default_handlers", ["require", "exports", "module", "ace/lib/dom", "ace/lib/event", "ace/lib/useragent"], function(e, t, n) { + "use strict"; + + function a(e) { + e.$clickSelection = null; + var t = e.editor; + t.setDefaultHandler("mousedown", this.onMouseDown.bind(e)), t.setDefaultHandler("dblclick", this.onDoubleClick.bind(e)), t.setDefaultHandler("tripleclick", this.onTripleClick.bind(e)), t.setDefaultHandler("quadclick", this.onQuadClick.bind(e)), t.setDefaultHandler("mousewheel", this.onMouseWheel.bind(e)), t.setDefaultHandler("touchmove", this.onTouchMove.bind(e)); + var n = ["select", "startSelect", "selectEnd", "selectAllEnd", "selectByWordsEnd", "selectByLinesEnd", "dragWait", "dragWaitEnd", "focusWait"]; + n.forEach(function(t) { + e[t] = this[t] + }, this), e.selectByLines = this.extendSelectionBy.bind(e, "getLineRange"), e.selectByWords = this.extendSelectionBy.bind(e, "getWordRange") + } + + function f(e, t, n, r) { + return Math.sqrt(Math.pow(n - e, 2) + Math.pow(r - t, 2)) + } + + function l(e, t) { + if (e.start.row == e.end.row) var n = 2 * t.column - e.start.column - e.end.column; + else if (e.start.row == e.end.row - 1 && !e.start.column && !e.end.column) var n = t.column - 4; + else var n = 2 * t.row - e.start.row - e.end.row; + return n < 0 ? { + cursor: e.start, + anchor: e.end + } : { + cursor: e.end, + anchor: e.start + } + } + var r = e("../lib/dom"), + i = e("../lib/event"), + s = e("../lib/useragent"), + o = 0, + u = 250; + (function() { + this.onMouseDown = function(e) { + var t = e.inSelection(), + n = e.getDocumentPosition(); + this.mousedownEvent = e; + var r = this.editor, + i = e.getButton(); + if (i !== 0) { + var o = r.getSelectionRange(), + u = o.isEmpty(); + r.$blockScrolling++, (u || i == 1) && r.selection.moveToPosition(n), r.$blockScrolling--, i == 2 && (r.textInput.onContextMenu(e.domEvent), s.isMozilla || e.preventDefault()); + return + } + this.mousedownEvent.time = Date.now(); + if (t && !r.isFocused()) { + r.focus(); + if (this.$focusTimout && !this.$clickSelection && !r.inMultiSelectMode) { + this.setState("focusWait"), this.captureMouse(e); + return + } + } + return this.captureMouse(e), this.startSelect(n, e.domEvent._clicks > 1), e.preventDefault() + }, this.startSelect = function(e, t) { + e = e || this.editor.renderer.screenToTextCoordinates(this.x, this.y); + var n = this.editor; + n.$blockScrolling++, this.mousedownEvent.getShiftKey() ? n.selection.selectToPosition(e) : t || n.selection.moveToPosition(e), t || this.select(), n.renderer.scroller.setCapture && n.renderer.scroller.setCapture(), n.setStyle("ace_selecting"), this.setState("select"), n.$blockScrolling-- + }, this.select = function() { + var e, t = this.editor, + n = t.renderer.screenToTextCoordinates(this.x, this.y); + t.$blockScrolling++; + if (this.$clickSelection) { + var r = this.$clickSelection.comparePoint(n); + if (r == -1) e = this.$clickSelection.end; + else if (r == 1) e = this.$clickSelection.start; + else { + var i = l(this.$clickSelection, n); + n = i.cursor, e = i.anchor + } + t.selection.setSelectionAnchor(e.row, e.column) + } + t.selection.selectToPosition(n), t.$blockScrolling--, t.renderer.scrollCursorIntoView() + }, this.extendSelectionBy = function(e) { + var t, n = this.editor, + r = n.renderer.screenToTextCoordinates(this.x, this.y), + i = n.selection[e](r.row, r.column); + n.$blockScrolling++; + if (this.$clickSelection) { + var s = this.$clickSelection.comparePoint(i.start), + o = this.$clickSelection.comparePoint(i.end); + if (s == -1 && o <= 0) { + t = this.$clickSelection.end; + if (i.end.row != r.row || i.end.column != r.column) r = i.start + } else if (o == 1 && s >= 0) { + t = this.$clickSelection.start; + if (i.start.row != r.row || i.start.column != r.column) r = i.end + } else if (s == -1 && o == 1) r = i.end, t = i.start; + else { + var u = l(this.$clickSelection, r); + r = u.cursor, t = u.anchor + } + n.selection.setSelectionAnchor(t.row, t.column) + } + n.selection.selectToPosition(r), n.$blockScrolling--, n.renderer.scrollCursorIntoView() + }, this.selectEnd = this.selectAllEnd = this.selectByWordsEnd = this.selectByLinesEnd = function() { + this.$clickSelection = null, this.editor.unsetStyle("ace_selecting"), this.editor.renderer.scroller.releaseCapture && this.editor.renderer.scroller.releaseCapture() + }, this.focusWait = function() { + var e = f(this.mousedownEvent.x, this.mousedownEvent.y, this.x, this.y), + t = Date.now(); + (e > o || t - this.mousedownEvent.time > this.$focusTimout) && this.startSelect(this.mousedownEvent.getDocumentPosition()) + }, this.onDoubleClick = function(e) { + var t = e.getDocumentPosition(), + n = this.editor, + r = n.session, + i = r.getBracketRange(t); + i ? (i.isEmpty() && (i.start.column--, i.end.column++), this.setState("select")) : (i = n.selection.getWordRange(t.row, t.column), this.setState("selectByWords")), this.$clickSelection = i, this.select() + }, this.onTripleClick = function(e) { + var t = e.getDocumentPosition(), + n = this.editor; + this.setState("selectByLines"); + var r = n.getSelectionRange(); + r.isMultiLine() && r.contains(t.row, t.column) ? (this.$clickSelection = n.selection.getLineRange(r.start.row), this.$clickSelection.end = n.selection.getLineRange(r.end.row).end) : this.$clickSelection = n.selection.getLineRange(t.row), this.select() + }, this.onQuadClick = function(e) { + var t = this.editor; + t.selectAll(), this.$clickSelection = t.getSelectionRange(), this.setState("selectAll") + }, this.onMouseWheel = function(e) { + if (e.getAccelKey()) return; + e.getShiftKey() && e.wheelY && !e.wheelX && (e.wheelX = e.wheelY, e.wheelY = 0); + var t = this.editor; + this.$lastScroll || (this.$lastScroll = { + t: 0, + vx: 0, + vy: 0, + allowed: 0 + }); + var n = this.$lastScroll, + r = e.domEvent.timeStamp, + i = r - n.t, + s = e.wheelX / i, + o = e.wheelY / i; + i < u && (s = (s + n.vx) / 2, o = (o + n.vy) / 2); + var a = Math.abs(s / o), + f = !1; + a >= 1 && t.renderer.isScrollableBy(e.wheelX * e.speed, 0) && (f = !0), a <= 1 && t.renderer.isScrollableBy(0, e.wheelY * e.speed) && (f = !0); + if (f) n.allowed = r; + else if (r - n.allowed < u) { + var l = Math.abs(s) <= 1.1 * Math.abs(n.vx) && Math.abs(o) <= 1.1 * Math.abs(n.vy); + l ? (f = !0, n.allowed = r) : n.allowed = 0 + } + n.t = r, n.vx = s, n.vy = o; + if (f) return t.renderer.scrollBy(e.wheelX * e.speed, e.wheelY * e.speed), e.stop() + }, this.onTouchMove = function(e) { + this.editor._emit("mousewheel", e) + } + }).call(a.prototype), t.DefaultHandlers = a +}), define("ace/tooltip", ["require", "exports", "module", "ace/lib/oop", "ace/lib/dom"], function(e, t, n) { + "use strict"; + + function s(e) { + this.isOpen = !1, this.$element = null, this.$parentNode = e + } + var r = e("./lib/oop"), + i = e("./lib/dom"); + (function() { + this.$init = function() { + return this.$element = i.createElement("div"), this.$element.className = "ace_tooltip", this.$element.style.display = "none", this.$parentNode.appendChild(this.$element), this.$element + }, this.getElement = function() { + return this.$element || this.$init() + }, this.setText = function(e) { + i.setInnerText(this.getElement(), e) + }, this.setHtml = function(e) { + this.getElement().innerHTML = e + }, this.setPosition = function(e, t) { + this.getElement().style.left = e + "px", this.getElement().style.top = t + "px" + }, this.setClassName = function(e) { + i.addCssClass(this.getElement(), e) + }, this.show = function(e, t, n) { + e != null && this.setText(e), t != null && n != null && this.setPosition(t, n), this.isOpen || (this.getElement().style.display = "block", this.isOpen = !0) + }, this.hide = function() { + this.isOpen && (this.getElement().style.display = "none", this.isOpen = !1) + }, this.getHeight = function() { + return this.getElement().offsetHeight + }, this.getWidth = function() { + return this.getElement().offsetWidth + }, this.destroy = function() { + this.isOpen = !1, this.$element && this.$element.parentNode && this.$element.parentNode.removeChild(this.$element) + } + }).call(s.prototype), t.Tooltip = s +}), define("ace/mouse/default_gutter_handler", ["require", "exports", "module", "ace/lib/dom", "ace/lib/oop", "ace/lib/event", "ace/tooltip"], function(e, t, n) { + "use strict"; + + function u(e) { + function l() { + var r = u.getDocumentPosition().row, + s = n.$annotations[r]; + if (!s) return c(); + var o = t.session.getLength(); + if (r == o) { + var a = t.renderer.pixelToScreenCoordinates(0, u.y).row, + l = u.$pos; + if (a > t.session.documentToScreenRow(l.row, l.column)) return c() + } + if (f == s) return; + f = s.text.join("
"), i.setHtml(f), i.show(), t._signal("showGutterTooltip", i), t.on("mousewheel", c); + if (e.$tooltipFollowsMouse) h(u); + else { + var p = u.domEvent.target, + d = p.getBoundingClientRect(), + v = i.getElement().style; + v.left = d.right + "px", v.top = d.bottom + "px" + } + } + + function c() { + o && (o = clearTimeout(o)), f && (i.hide(), f = null, t._signal("hideGutterTooltip", i), t.removeEventListener("mousewheel", c)) + } + + function h(e) { + i.setPosition(e.x, e.y) + } + var t = e.editor, + n = t.renderer.$gutterLayer, + i = new a(t.container); + e.editor.setDefaultHandler("guttermousedown", function(r) { + if (!t.isFocused() || r.getButton() != 0) return; + var i = n.getRegion(r); + if (i == "foldWidgets") return; + var s = r.getDocumentPosition().row, + o = t.session.selection; + if (r.getShiftKey()) o.selectTo(s, 0); + else { + if (r.domEvent.detail == 2) return t.selectAll(), r.preventDefault(); + e.$clickSelection = t.selection.getLineRange(s) + } + return e.setState("selectByLines"), e.captureMouse(r), r.preventDefault() + }); + var o, u, f; + e.editor.setDefaultHandler("guttermousemove", function(t) { + var n = t.domEvent.target || t.domEvent.srcElement; + if (r.hasCssClass(n, "ace_fold-widget")) return c(); + f && e.$tooltipFollowsMouse && h(t), u = t; + if (o) return; + o = setTimeout(function() { + o = null, u && !e.isMousePressed ? l() : c() + }, 50) + }), s.addListener(t.renderer.$gutter, "mouseout", function(e) { + u = null; + if (!f || o) return; + o = setTimeout(function() { + o = null, c() + }, 50) + }), t.on("changeSession", c) + } + + function a(e) { + o.call(this, e) + } + var r = e("../lib/dom"), + i = e("../lib/oop"), + s = e("../lib/event"), + o = e("../tooltip").Tooltip; + i.inherits(a, o), + function() { + this.setPosition = function(e, t) { + var n = window.innerWidth || document.documentElement.clientWidth, + r = window.innerHeight || document.documentElement.clientHeight, + i = this.getWidth(), + s = this.getHeight(); + e += 15, t += 15, e + i > n && (e -= e + i - n), t + s > r && (t -= 20 + s), o.prototype.setPosition.call(this, e, t) + } + }.call(a.prototype), t.GutterHandler = u +}), define("ace/mouse/mouse_event", ["require", "exports", "module", "ace/lib/event", "ace/lib/useragent"], function(e, t, n) { + "use strict"; + var r = e("../lib/event"), + i = e("../lib/useragent"), + s = t.MouseEvent = function(e, t) { + this.domEvent = e, this.editor = t, this.x = this.clientX = e.clientX, this.y = this.clientY = e.clientY, this.$pos = null, this.$inSelection = null, this.propagationStopped = !1, this.defaultPrevented = !1 + }; + (function() { + this.stopPropagation = function() { + r.stopPropagation(this.domEvent), this.propagationStopped = !0 + }, this.preventDefault = function() { + r.preventDefault(this.domEvent), this.defaultPrevented = !0 + }, this.stop = function() { + this.stopPropagation(), this.preventDefault() + }, this.getDocumentPosition = function() { + return this.$pos ? this.$pos : (this.$pos = this.editor.renderer.screenToTextCoordinates(this.clientX, this.clientY), this.$pos) + }, this.inSelection = function() { + if (this.$inSelection !== null) return this.$inSelection; + var e = this.editor, + t = e.getSelectionRange(); + if (t.isEmpty()) this.$inSelection = !1; + else { + var n = this.getDocumentPosition(); + this.$inSelection = t.contains(n.row, n.column) + } + return this.$inSelection + }, this.getButton = function() { + return r.getButton(this.domEvent) + }, this.getShiftKey = function() { + return this.domEvent.shiftKey + }, this.getAccelKey = i.isMac ? function() { + return this.domEvent.metaKey + } : function() { + return this.domEvent.ctrlKey + } + }).call(s.prototype) +}), define("ace/mouse/dragdrop_handler", ["require", "exports", "module", "ace/lib/dom", "ace/lib/event", "ace/lib/useragent"], function(e, t, n) { + "use strict"; + + function f(e) { + function T(e, n) { + var r = Date.now(), + i = !n || e.row != n.row, + s = !n || e.column != n.column; + if (!S || i || s) t.$blockScrolling += 1, t.moveCursorToPosition(e), t.$blockScrolling -= 1, S = r, x = { + x: p, + y: d + }; + else { + var o = l(x.x, x.y, p, d); + o > a ? S = null : r - S >= u && (t.renderer.scrollCursorIntoView(), S = null) + } + } + + function N(e, n) { + var r = Date.now(), + i = t.renderer.layerConfig.lineHeight, + s = t.renderer.layerConfig.characterWidth, + u = t.renderer.scroller.getBoundingClientRect(), + a = { + x: { + left: p - u.left, + right: u.right - p + }, + y: { + top: d - u.top, + bottom: u.bottom - d + } + }, + f = Math.min(a.x.left, a.x.right), + l = Math.min(a.y.top, a.y.bottom), + c = { + row: e.row, + column: e.column + }; + f / s <= 2 && (c.column += a.x.left < a.x.right ? -3 : 2), l / i <= 1 && (c.row += a.y.top < a.y.bottom ? -1 : 1); + var h = e.row != c.row, + v = e.column != c.column, + m = !n || e.row != n.row; + h || v && !m ? E ? r - E >= o && t.renderer.scrollCursorIntoView(c) : E = r : E = null + } + + function C() { + var e = g; + g = t.renderer.screenToTextCoordinates(p, d), T(g, e), N(g, e) + } + + function k() { + m = t.selection.toOrientedRange(), h = t.session.addMarker(m, "ace_selection", t.getSelectionStyle()), t.clearSelection(), t.isFocused() && t.renderer.$cursorLayer.setBlinking(!1), clearInterval(v), C(), v = setInterval(C, 20), y = 0, i.addListener(document, "mousemove", O) + } + + function L() { + clearInterval(v), t.session.removeMarker(h), h = null, t.$blockScrolling += 1, t.selection.fromOrientedRange(m), t.$blockScrolling -= 1, t.isFocused() && !w && t.renderer.$cursorLayer.setBlinking(!t.getReadOnly()), m = null, g = null, y = 0, E = null, S = null, i.removeListener(document, "mousemove", O) + } + + function O() { + A == null && (A = setTimeout(function() { + A != null && h && L() + }, 20)) + } + + function M(e) { + var t = e.types; + return !t || Array.prototype.some.call(t, function(e) { + return e == "text/plain" || e == "Text" + }) + } + + function _(e) { + var t = ["copy", "copymove", "all", "uninitialized"], + n = ["move", "copymove", "linkmove", "all", "uninitialized"], + r = s.isMac ? e.altKey : e.ctrlKey, + i = "uninitialized"; + try { + i = e.dataTransfer.effectAllowed.toLowerCase() + } catch (e) {} + var o = "none"; + return r && t.indexOf(i) >= 0 ? o = "copy" : n.indexOf(i) >= 0 ? o = "move" : t.indexOf(i) >= 0 && (o = "copy"), o + } + var t = e.editor, + n = r.createElement("img"); + n.src = "data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==", s.isOpera && (n.style.cssText = "width:1px;height:1px;position:fixed;top:0;left:0;z-index:2147483647;opacity:0;"); + var f = ["dragWait", "dragWaitEnd", "startDrag", "dragReadyEnd", "onMouseDrag"]; + f.forEach(function(t) { + e[t] = this[t] + }, this), t.addEventListener("mousedown", this.onMouseDown.bind(e)); + var c = t.container, + h, p, d, v, m, g, y = 0, + b, w, E, S, x; + this.onDragStart = function(e) { + if (this.cancelDrag || !c.draggable) { + var r = this; + return setTimeout(function() { + r.startSelect(), r.captureMouse(e) + }, 0), e.preventDefault() + } + m = t.getSelectionRange(); + var i = e.dataTransfer; + i.effectAllowed = t.getReadOnly() ? "copy" : "copyMove", s.isOpera && (t.container.appendChild(n), n.scrollTop = 0), i.setDragImage && i.setDragImage(n, 0, 0), s.isOpera && t.container.removeChild(n), i.clearData(), i.setData("Text", t.session.getTextRange()), w = !0, this.setState("drag") + }, this.onDragEnd = function(e) { + c.draggable = !1, w = !1, this.setState(null); + if (!t.getReadOnly()) { + var n = e.dataTransfer.dropEffect; + !b && n == "move" && t.session.remove(t.getSelectionRange()), t.renderer.$cursorLayer.setBlinking(!0) + } + this.editor.unsetStyle("ace_dragging"), this.editor.renderer.setCursorStyle("") + }, this.onDragEnter = function(e) { + if (t.getReadOnly() || !M(e.dataTransfer)) return; + return p = e.clientX, d = e.clientY, h || k(), y++, e.dataTransfer.dropEffect = b = _(e), i.preventDefault(e) + }, this.onDragOver = function(e) { + if (t.getReadOnly() || !M(e.dataTransfer)) return; + return p = e.clientX, d = e.clientY, h || (k(), y++), A !== null && (A = null), e.dataTransfer.dropEffect = b = _(e), i.preventDefault(e) + }, this.onDragLeave = function(e) { + y--; + if (y <= 0 && h) return L(), b = null, i.preventDefault(e) + }, this.onDrop = function(e) { + if (!g) return; + var n = e.dataTransfer; + if (w) switch (b) { + case "move": + m.contains(g.row, g.column) ? m = { + start: g, + end: g + } : m = t.moveText(m, g); + break; + case "copy": + m = t.moveText(m, g, !0) + } else { + var r = n.getData("Text"); + m = { + start: g, + end: t.session.insert(g, r) + }, t.focus(), b = null + } + return L(), i.preventDefault(e) + }, i.addListener(c, "dragstart", this.onDragStart.bind(e)), i.addListener(c, "dragend", this.onDragEnd.bind(e)), i.addListener(c, "dragenter", this.onDragEnter.bind(e)), i.addListener(c, "dragover", this.onDragOver.bind(e)), i.addListener(c, "dragleave", this.onDragLeave.bind(e)), i.addListener(c, "drop", this.onDrop.bind(e)); + var A = null + } + + function l(e, t, n, r) { + return Math.sqrt(Math.pow(n - e, 2) + Math.pow(r - t, 2)) + } + var r = e("../lib/dom"), + i = e("../lib/event"), + s = e("../lib/useragent"), + o = 200, + u = 200, + a = 5; + (function() { + this.dragWait = function() { + var e = Date.now() - this.mousedownEvent.time; + e > this.editor.getDragDelay() && this.startDrag() + }, this.dragWaitEnd = function() { + var e = this.editor.container; + e.draggable = !1, this.startSelect(this.mousedownEvent.getDocumentPosition()), this.selectEnd() + }, this.dragReadyEnd = function(e) { + this.editor.renderer.$cursorLayer.setBlinking(!this.editor.getReadOnly()), this.editor.unsetStyle("ace_dragging"), this.editor.renderer.setCursorStyle(""), this.dragWaitEnd() + }, this.startDrag = function() { + this.cancelDrag = !1; + var e = this.editor, + t = e.container; + t.draggable = !0, e.renderer.$cursorLayer.setBlinking(!1), e.setStyle("ace_dragging"); + var n = s.isWin ? "default" : "move"; + e.renderer.setCursorStyle(n), this.setState("dragReady") + }, this.onMouseDrag = function(e) { + var t = this.editor.container; + if (s.isIE && this.state == "dragReady") { + var n = l(this.mousedownEvent.x, this.mousedownEvent.y, this.x, this.y); + n > 3 && t.dragDrop() + } + if (this.state === "dragWait") { + var n = l(this.mousedownEvent.x, this.mousedownEvent.y, this.x, this.y); + n > 0 && (t.draggable = !1, this.startSelect(this.mousedownEvent.getDocumentPosition())) + } + }, this.onMouseDown = function(e) { + if (!this.$dragEnabled) return; + this.mousedownEvent = e; + var t = this.editor, + n = e.inSelection(), + r = e.getButton(), + i = e.domEvent.detail || 1; + if (i === 1 && r === 0 && n) { + if (e.editor.inMultiSelectMode && (e.getAccelKey() || e.getShiftKey())) return; + this.mousedownEvent.time = Date.now(); + var o = e.domEvent.target || e.domEvent.srcElement; + "unselectable" in o && (o.unselectable = "on"); + if (t.getDragDelay()) { + if (s.isWebKit) { + this.cancelDrag = !0; + var u = t.container; + u.draggable = !0 + } + this.setState("dragWait") + } else this.startDrag(); + this.captureMouse(e, this.onMouseDrag.bind(this)), e.defaultPrevented = !0 + } + } + }).call(f.prototype), t.DragdropHandler = f +}), define("ace/lib/net", ["require", "exports", "module", "ace/lib/dom"], function(e, t, n) { + "use strict"; + var r = e("./dom"); + t.get = function(e, t) { + var n = new XMLHttpRequest; + n.open("GET", e, !0), n.onreadystatechange = function() { + n.readyState === 4 && t(n.responseText) + }, n.send(null) + }, t.loadScript = function(e, t) { + var n = r.getDocumentHead(), + i = document.createElement("script"); + i.src = e, n.appendChild(i), i.onload = i.onreadystatechange = function(e, n) { + if (n || !i.readyState || i.readyState == "loaded" || i.readyState == "complete") i = i.onload = i.onreadystatechange = null, n || t() + } + }, t.qualifyURL = function(e) { + var t = document.createElement("a"); + return t.href = e, t.href + } +}), define("ace/lib/event_emitter", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + var r = {}, + i = function() { + this.propagationStopped = !0 + }, + s = function() { + this.defaultPrevented = !0 + }; + r._emit = r._dispatchEvent = function(e, t) { + this._eventRegistry || (this._eventRegistry = {}), this._defaultHandlers || (this._defaultHandlers = {}); + var n = this._eventRegistry[e] || [], + r = this._defaultHandlers[e]; + if (!n.length && !r) return; + if (typeof t != "object" || !t) t = {}; + t.type || (t.type = e), t.stopPropagation || (t.stopPropagation = i), t.preventDefault || (t.preventDefault = s), n = n.slice(); + for (var o = 0; o < n.length; o++) { + n[o](t, this); + if (t.propagationStopped) break + } + if (r && !t.defaultPrevented) return r(t, this) + }, r._signal = function(e, t) { + var n = (this._eventRegistry || {})[e]; + if (!n) return; + n = n.slice(); + for (var r = 0; r < n.length; r++) n[r](t, this) + }, r.once = function(e, t) { + var n = this; + t && this.addEventListener(e, function r() { + n.removeEventListener(e, r), t.apply(null, arguments) + }) + }, r.setDefaultHandler = function(e, t) { + var n = this._defaultHandlers; + n || (n = this._defaultHandlers = { + _disabled_: {} + }); + if (n[e]) { + var r = n[e], + i = n._disabled_[e]; + i || (n._disabled_[e] = i = []), i.push(r); + var s = i.indexOf(t); + s != -1 && i.splice(s, 1) + } + n[e] = t + }, r.removeDefaultHandler = function(e, t) { + var n = this._defaultHandlers; + if (!n) return; + var r = n._disabled_[e]; + if (n[e] == t) { + var i = n[e]; + r && this.setDefaultHandler(e, r.pop()) + } else if (r) { + var s = r.indexOf(t); + s != -1 && r.splice(s, 1) + } + }, r.on = r.addEventListener = function(e, t, n) { + this._eventRegistry = this._eventRegistry || {}; + var r = this._eventRegistry[e]; + return r || (r = this._eventRegistry[e] = []), r.indexOf(t) == -1 && r[n ? "unshift" : "push"](t), t + }, r.off = r.removeListener = r.removeEventListener = function(e, t) { + this._eventRegistry = this._eventRegistry || {}; + var n = this._eventRegistry[e]; + if (!n) return; + var r = n.indexOf(t); + r !== -1 && n.splice(r, 1) + }, r.removeAllListeners = function(e) { + this._eventRegistry && (this._eventRegistry[e] = []) + }, t.EventEmitter = r +}), define("ace/lib/app_config", ["require", "exports", "module", "ace/lib/oop", "ace/lib/event_emitter"], function(e, t, n) { + "no use strict"; + + function o(e) { + typeof console != "undefined" && console.warn && console.warn.apply(console, arguments) + } + + function u(e, t) { + var n = new Error(e); + n.data = t, typeof console == "object" && console.error && console.error(n), setTimeout(function() { + throw n + }) + } + var r = e("./oop"), + i = e("./event_emitter").EventEmitter, + s = { + setOptions: function(e) { + Object.keys(e).forEach(function(t) { + this.setOption(t, e[t]) + }, this) + }, + getOptions: function(e) { + var t = {}; + return e ? Array.isArray(e) || (t = e, e = Object.keys(t)) : e = Object.keys(this.$options), e.forEach(function(e) { + t[e] = this.getOption(e) + }, this), t + }, + setOption: function(e, t) { + if (this["$" + e] === t) return; + var n = this.$options[e]; + if (!n) return o('misspelled option "' + e + '"'); + if (n.forwardTo) return this[n.forwardTo] && this[n.forwardTo].setOption(e, t); + n.handlesSet || (this["$" + e] = t), n && n.set && n.set.call(this, t) + }, + getOption: function(e) { + var t = this.$options[e]; + return t ? t.forwardTo ? this[t.forwardTo] && this[t.forwardTo].getOption(e) : t && t.get ? t.get.call(this) : this["$" + e] : o('misspelled option "' + e + '"') + } + }, + a = function() { + this.$defaultOptions = {} + }; + (function() { + r.implement(this, i), this.defineOptions = function(e, t, n) { + return e.$options || (this.$defaultOptions[t] = e.$options = {}), Object.keys(n).forEach(function(t) { + var r = n[t]; + typeof r == "string" && (r = { + forwardTo: r + }), r.name || (r.name = t), e.$options[r.name] = r, "initialValue" in r && (e["$" + r.name] = r.initialValue) + }), r.implement(e, s), this + }, this.resetOptions = function(e) { + Object.keys(e.$options).forEach(function(t) { + var n = e.$options[t]; + "value" in n && e.setOption(t, n.value) + }) + }, this.setDefaultValue = function(e, t, n) { + var r = this.$defaultOptions[e] || (this.$defaultOptions[e] = {}); + r[t] && (r.forwardTo ? this.setDefaultValue(r.forwardTo, t, n) : r[t].value = n) + }, this.setDefaultValues = function(e, t) { + Object.keys(t).forEach(function(n) { + this.setDefaultValue(e, n, t[n]) + }, this) + }, this.warn = o, this.reportError = u + }).call(a.prototype), t.AppConfig = a +}), define("ace/config", ["require", "exports", "module", "ace/lib/lang", "ace/lib/oop", "ace/lib/net", "ace/lib/app_config"], function(e, t, n) { + "no use strict"; + + function f(r) { + if (!u || !u.document) return; + a.packaged = r || e.packaged || n.packaged || u.define && define.packaged; + var i = {}, + s = "", + o = document.currentScript || document._currentScript, + f = o && o.ownerDocument || document, + c = f.getElementsByTagName("script"); + for (var h = 0; h < c.length; h++) { + var p = c[h], + d = p.src || p.getAttribute("src"); + if (!d) continue; + var v = p.attributes; + for (var m = 0, g = v.length; m < g; m++) { + var y = v[m]; + y.name.indexOf("data-ace-") === 0 && (i[l(y.name.replace(/^data-ace-/, ""))] = y.value) + } + var b = d.match(/^(.*)\/ace(\-\w+)?\.js(\?|$)/); + b && (s = b[1]) + } + s && (i.base = i.base || s, i.packaged = !0), i.basePath = i.base, i.workerPath = i.workerPath || i.base, i.modePath = i.modePath || i.base, i.themePath = i.themePath || i.base, delete i.base; + for (var w in i) typeof i[w] != "undefined" && t.set(w, i[w]) + } + + function l(e) { + return e.replace(/-(.)/g, function(e, t) { + return t.toUpperCase() + }) + } + var r = e("./lib/lang"), + i = e("./lib/oop"), + s = e("./lib/net"), + o = e("./lib/app_config").AppConfig; + n.exports = t = new o; + var u = function() { + return this || typeof window != "undefined" && window + }(), + a = { + packaged: !1, + workerPath: null, + modePath: null, + themePath: null, + basePath: "", + suffix: ".js", + $moduleUrls: { + "ace/mode/css_worker": "https://cdnjs.cloudflare.com/ajax/libs/ace/1.2.9/worker-css.js" + } + }; + t.get = function(e) { + if (!a.hasOwnProperty(e)) throw new Error("Unknown config key: " + e); + return a[e] + }, t.set = function(e, t) { + if (!a.hasOwnProperty(e)) throw new Error("Unknown config key: " + e); + a[e] = t + }, t.all = function() { + return r.copyObject(a) + }, t.moduleUrl = function(e, t) { + if (a.$moduleUrls[e]) return a.$moduleUrls[e]; + console.log("Unsupported require from ace:", e) + var n = e.split("/"); + t = t || n[n.length - 2] || ""; + var r = t == "snippets" ? "/" : "-", + i = n[n.length - 1]; + if (t == "worker" && r == "-") { + var s = new RegExp("^" + t + "[\\-_]|[\\-_]" + t + "$", "g"); + i = i.replace(s, "") + }(!i || i == t) && n.length > 1 && (i = n[n.length - 2]); + var o = a[t + "Path"]; + return o == null ? o = a.basePath : r == "/" && (t = r = ""), o && o.slice(-1) != "/" && (o += "/"), o + t + r + i + this.get("suffix") + }, t.setModuleUrl = function(e, t) { + return a.$moduleUrls[e] = t + }, t.$loading = {}, t.loadModule = function(n, r) { + var i, o; + Array.isArray(n) && (o = n[0], n = n[1]); + try { + i = e(n) + } catch (u) {} + if (i && !t.$loading[n]) return r && r(i); + t.$loading[n] || (t.$loading[n] = []), t.$loading[n].push(r); + if (t.$loading[n].length > 1) return; + var a = function() { + e([n], function(e) { + t._emit("load.module", { + name: n, + module: e + }); + var r = t.$loading[n]; + t.$loading[n] = null, r.forEach(function(t) { + t && t(e) + }) + }) + }; + if (!t.get("packaged")) return a(); + s.loadScript(t.moduleUrl(n, o), a) + }, t.init = f +}), define("ace/mouse/mouse_handler", ["require", "exports", "module", "ace/lib/event", "ace/lib/useragent", "ace/mouse/default_handlers", "ace/mouse/default_gutter_handler", "ace/mouse/mouse_event", "ace/mouse/dragdrop_handler", "ace/config"], function(e, t, n) { + "use strict"; + var r = e("../lib/event"), + i = e("../lib/useragent"), + s = e("./default_handlers").DefaultHandlers, + o = e("./default_gutter_handler").GutterHandler, + u = e("./mouse_event").MouseEvent, + a = e("./dragdrop_handler").DragdropHandler, + f = e("../config"), + l = function(e) { + var t = this; + this.editor = e, new s(this), new o(this), new a(this); + var n = function(t) { + var n = !document.hasFocus || !document.hasFocus() || !e.isFocused() && document.activeElement == (e.textInput && e.textInput.getElement()); + n && window.focus(), e.focus() + }, + u = e.renderer.getMouseEventTarget(); + r.addListener(u, "click", this.onMouseEvent.bind(this, "click")), r.addListener(u, "mousemove", this.onMouseMove.bind(this, "mousemove")), r.addMultiMouseDownListener([u, e.renderer.scrollBarV && e.renderer.scrollBarV.inner, e.renderer.scrollBarH && e.renderer.scrollBarH.inner, e.textInput && e.textInput.getElement()].filter(Boolean), [400, 300, 250], this, "onMouseEvent"), r.addMouseWheelListener(e.container, this.onMouseWheel.bind(this, "mousewheel")), r.addTouchMoveListener(e.container, this.onTouchMove.bind(this, "touchmove")); + var f = e.renderer.$gutter; + r.addListener(f, "mousedown", this.onMouseEvent.bind(this, "guttermousedown")), r.addListener(f, "click", this.onMouseEvent.bind(this, "gutterclick")), r.addListener(f, "dblclick", this.onMouseEvent.bind(this, "gutterdblclick")), r.addListener(f, "mousemove", this.onMouseEvent.bind(this, "guttermousemove")), r.addListener(u, "mousedown", n), r.addListener(f, "mousedown", n), i.isIE && e.renderer.scrollBarV && (r.addListener(e.renderer.scrollBarV.element, "mousedown", n), r.addListener(e.renderer.scrollBarH.element, "mousedown", n)), e.on("mousemove", function(n) { + if (t.state || t.$dragDelay || !t.$dragEnabled) return; + var r = e.renderer.screenToTextCoordinates(n.x, n.y), + i = e.session.selection.getRange(), + s = e.renderer; + !i.isEmpty() && i.insideStart(r.row, r.column) ? s.setCursorStyle("default") : s.setCursorStyle("") + }) + }; + (function() { + this.onMouseEvent = function(e, t) { + this.editor._emit(e, new u(t, this.editor)) + }, this.onMouseMove = function(e, t) { + var n = this.editor._eventRegistry && this.editor._eventRegistry.mousemove; + if (!n || !n.length) return; + this.editor._emit(e, new u(t, this.editor)) + }, this.onMouseWheel = function(e, t) { + var n = new u(t, this.editor); + n.speed = this.$scrollSpeed * 2, n.wheelX = t.wheelX, n.wheelY = t.wheelY, this.editor._emit(e, n) + }, this.onTouchMove = function(e, t) { + var n = new u(t, this.editor); + n.speed = 1, n.wheelX = t.wheelX, n.wheelY = t.wheelY, this.editor._emit(e, n) + }, this.setState = function(e) { + this.state = e + }, this.captureMouse = function(e, t) { + this.x = e.x, this.y = e.y, this.isMousePressed = !0; + var n = this.editor.renderer; + n.$keepTextAreaAtCursor && (n.$keepTextAreaAtCursor = null); + var s = this, + o = function(e) { + if (!e) return; + if (i.isWebKit && !e.which && s.releaseMouse) return s.releaseMouse(); + s.x = e.clientX, s.y = e.clientY, t && t(e), s.mouseEvent = new u(e, s.editor), s.$mouseMoved = !0 + }, + a = function(e) { + clearInterval(l), f(), s[s.state + "End"] && s[s.state + "End"](e), s.state = "", n.$keepTextAreaAtCursor == null && (n.$keepTextAreaAtCursor = !0, n.$moveTextAreaToCursor()), s.isMousePressed = !1, s.$onCaptureMouseMove = s.releaseMouse = null, e && s.onMouseEvent("mouseup", e) + }, + f = function() { + s[s.state] && s[s.state](), s.$mouseMoved = !1 + }; + if (i.isOldIE && e.domEvent.type == "dblclick") return setTimeout(function() { + a(e) + }); + s.$onCaptureMouseMove = o, s.releaseMouse = r.capture(this.editor.container, o, a); + var l = setInterval(f, 20) + }, this.releaseMouse = null, this.cancelContextMenu = function() { + var e = function(t) { + if (t && t.domEvent && t.domEvent.type != "contextmenu") return; + this.editor.off("nativecontextmenu", e), t && t.domEvent && r.stopEvent(t.domEvent) + }.bind(this); + setTimeout(e, 10), this.editor.on("nativecontextmenu", e) + } + }).call(l.prototype), f.defineOptions(l.prototype, "mouseHandler", { + scrollSpeed: { + initialValue: 2 + }, + dragDelay: { + initialValue: i.isMac ? 150 : 0 + }, + dragEnabled: { + initialValue: !0 + }, + focusTimout: { + initialValue: 0 + }, + tooltipFollowsMouse: { + initialValue: !0 + } + }), t.MouseHandler = l +}), define("ace/mouse/fold_handler", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + + function r(e) { + e.on("click", function(t) { + var n = t.getDocumentPosition(), + r = e.session, + i = r.getFoldAt(n.row, n.column, 1); + i && (t.getAccelKey() ? r.removeFold(i) : r.expandFold(i), t.stop()) + }), e.on("gutterclick", function(t) { + var n = e.renderer.$gutterLayer.getRegion(t); + if (n == "foldWidgets") { + var r = t.getDocumentPosition().row, + i = e.session; + i.foldWidgets && i.foldWidgets[r] && e.session.onFoldWidgetClick(r, t), e.isFocused() || e.focus(), t.stop() + } + }), e.on("gutterdblclick", function(t) { + var n = e.renderer.$gutterLayer.getRegion(t); + if (n == "foldWidgets") { + var r = t.getDocumentPosition().row, + i = e.session, + s = i.getParentFoldRangeData(r, !0), + o = s.range || s.firstRange; + if (o) { + r = o.start.row; + var u = i.getFoldAt(r, i.getLine(r).length, 1); + u ? i.removeFold(u) : (i.addFold("...", o), e.renderer.scrollCursorIntoView({ + row: o.start.row, + column: 0 + })) + } + t.stop() + } + }) + } + t.FoldHandler = r +}), define("ace/keyboard/keybinding", ["require", "exports", "module", "ace/lib/keys", "ace/lib/event"], function(e, t, n) { + "use strict"; + var r = e("../lib/keys"), + i = e("../lib/event"), + s = function(e) { + this.$editor = e, this.$data = { + editor: e + }, this.$handlers = [], this.setDefaultHandler(e.commands) + }; + (function() { + this.setDefaultHandler = function(e) { + this.removeKeyboardHandler(this.$defaultHandler), this.$defaultHandler = e, this.addKeyboardHandler(e, 0) + }, this.setKeyboardHandler = function(e) { + var t = this.$handlers; + if (t[t.length - 1] == e) return; + while (t[t.length - 1] && t[t.length - 1] != this.$defaultHandler) this.removeKeyboardHandler(t[t.length - 1]); + this.addKeyboardHandler(e, 1) + }, this.addKeyboardHandler = function(e, t) { + if (!e) return; + typeof e == "function" && !e.handleKeyboard && (e.handleKeyboard = e); + var n = this.$handlers.indexOf(e); + n != -1 && this.$handlers.splice(n, 1), t == undefined ? this.$handlers.push(e) : this.$handlers.splice(t, 0, e), n == -1 && e.attach && e.attach(this.$editor) + }, this.removeKeyboardHandler = function(e) { + var t = this.$handlers.indexOf(e); + return t == -1 ? !1 : (this.$handlers.splice(t, 1), e.detach && e.detach(this.$editor), !0) + }, this.getKeyboardHandler = function() { + return this.$handlers[this.$handlers.length - 1] + }, this.getStatusText = function() { + var e = this.$data, + t = e.editor; + return this.$handlers.map(function(n) { + return n.getStatusText && n.getStatusText(t, e) || "" + }).filter(Boolean).join(" ") + }, this.$callKeyboardHandlers = function(e, t, n, r) { + var s, o = !1, + u = this.$editor.commands; + for (var a = this.$handlers.length; a--;) { + s = this.$handlers[a].handleKeyboard(this.$data, e, t, n, r); + if (!s || !s.command) continue; + s.command == "null" ? o = !0 : o = u.exec(s.command, this.$editor, s.args, r), o && r && e != -1 && s.passEvent != 1 && s.command.passEvent != 1 && i.stopEvent(r); + if (o) break + } + return !o && e == -1 && (s = { + command: "insertstring" + }, o = u.exec("insertstring", this.$editor, t)), o && this.$editor._signal && this.$editor._signal("keyboardActivity", s), o + }, this.onCommandKey = function(e, t, n) { + var i = r.keyCodeToString(n); + this.$callKeyboardHandlers(t, i, n, e) + }, this.onTextInput = function(e) { + this.$callKeyboardHandlers(-1, e) + } + }).call(s.prototype), t.KeyBinding = s +}), define("ace/lib/bidiutil", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + + function F(e, t, n, r) { + var i = s ? d : p, + c = null, + h = null, + v = null, + m = 0, + g = null, + y = null, + b = -1, + w = null, + E = null, + T = []; + if (!r) + for (w = 0, r = []; w < n; w++) r[w] = R(e[w]); + o = s, u = !1, a = !1, f = !1, l = !1; + for (E = 0; E < n; E++) { + c = m, T[E] = h = q(e, r, T, E), m = i[c][h], g = m & 240, m &= 15, t[E] = v = i[m][5]; + if (g > 0) + if (g == 16) { + for (w = b; w < E; w++) t[w] = 1; + b = -1 + } else b = -1; + y = i[m][6]; + if (y) b == -1 && (b = E); + else if (b > -1) { + for (w = b; w < E; w++) t[w] = v; + b = -1 + } + r[E] == S && (t[E] = 0), o |= v + } + if (l) + for (w = 0; w < n; w++) + if (r[w] == x) { + t[w] = s; + for (var C = w - 1; C >= 0; C--) { + if (r[C] != N) break; + t[C] = s + } + } + } + + function I(e, t, n) { + if (o < e) return; + if (e == 1 && s == m && !f) { + n.reverse(); + return + } + var r = n.length, + i = 0, + u, a, l, c; + while (i < r) { + if (t[i] >= e) { + u = i + 1; + while (u < r && t[u] >= e) u++; + for (a = i, l = u - 1; a < l; a++, l--) c = n[a], n[a] = n[l], n[l] = c; + i = u + } + i++ + } + } + + function q(e, t, n, r) { + var i = t[r], + o, c, h, p; + switch (i) { + case g: + case y: + u = !1; + case E: + case w: + return i; + case b: + return u ? w : b; + case T: + return u = !0, a = !0, y; + case N: + return E; + case C: + if (r < 1 || r + 1 >= t.length || (o = n[r - 1]) != b && o != w || (c = t[r + 1]) != b && c != w) return E; + return u && (c = w), c == o ? c : E; + case k: + o = r > 0 ? n[r - 1] : S; + if (o == b && r + 1 < t.length && t[r + 1] == b) return b; + return E; + case L: + if (r > 0 && n[r - 1] == b) return b; + if (u) return E; + p = r + 1, h = t.length; + while (p < h && t[p] == L) p++; + if (p < h && t[p] == b) return b; + return E; + case A: + h = t.length, p = r + 1; + while (p < h && t[p] == A) p++; + if (p < h) { + var d = e[r], + v = d >= 1425 && d <= 2303 || d == 64286; + o = t[p]; + if (v && (o == y || o == T)) return y + } + if (r < 1 || (o = t[r - 1]) == S) return E; + return n[r - 1]; + case S: + return u = !1, f = !0, s; + case x: + return l = !0, E; + case O: + case M: + case D: + case P: + case _: + u = !1; + case H: + return E + } + } + + function R(e) { + var t = e.charCodeAt(0), + n = t >> 8; + return n == 0 ? t > 191 ? g : B[t] : n == 5 ? /[\u0591-\u05f4]/.test(e) ? y : g : n == 6 ? /[\u0610-\u061a\u064b-\u065f\u06d6-\u06e4\u06e7-\u06ed]/.test(e) ? A : /[\u0660-\u0669\u066b-\u066c]/.test(e) ? w : t == 1642 ? L : /[\u06f0-\u06f9]/.test(e) ? b : T : n == 32 && t <= 8287 ? j[t & 255] : n == 254 ? t >= 65136 ? T : E : E + } + + function U(e) { + return e >= "\u064b" && e <= "\u0655" + } + var r = ["\u0621", "\u0641"], + i = ["\u063a", "\u064a"], + s = 0, + o = 0, + u = !1, + a = !1, + f = !1, + l = !1, + c = !1, + h = !1, + p = [ + [0, 3, 0, 1, 0, 0, 0], + [0, 3, 0, 1, 2, 2, 0], + [0, 3, 0, 17, 2, 0, 1], + [0, 3, 5, 5, 4, 1, 0], + [0, 3, 21, 21, 4, 0, 1], + [0, 3, 5, 5, 4, 2, 0] + ], + d = [ + [2, 0, 1, 1, 0, 1, 0], + [2, 0, 1, 1, 0, 2, 0], + [2, 0, 2, 1, 3, 2, 0], + [2, 0, 2, 33, 3, 1, 1] + ], + v = 0, + m = 1, + g = 0, + y = 1, + b = 2, + w = 3, + E = 4, + S = 5, + x = 6, + T = 7, + N = 8, + C = 9, + k = 10, + L = 11, + A = 12, + O = 13, + M = 14, + _ = 15, + D = 16, + P = 17, + H = 18, + B = [H, H, H, H, H, H, H, H, H, x, S, x, N, S, H, H, H, H, H, H, H, H, H, H, H, H, H, H, S, S, S, x, N, E, E, L, L, L, E, E, E, E, E, k, C, k, C, C, b, b, b, b, b, b, b, b, b, b, C, E, E, E, E, E, E, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, E, E, E, E, E, E, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, g, E, E, E, E, H, H, H, H, H, H, S, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, H, C, E, L, L, L, L, E, E, E, E, g, E, E, H, E, E, L, L, b, b, E, g, E, E, E, b, g, E, E, E, E, E], + j = [N, N, N, N, N, N, N, N, N, N, N, H, H, H, g, y, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, N, S, O, M, _, D, P, C, L, L, L, L, L, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, C, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, E, N]; + t.L = g, t.R = y, t.EN = b, t.ON_R = 3, t.AN = 4, t.R_H = 5, t.B = 6, t.DOT = "\u00b7", t.doBidiReorder = function(e, n, r) { + if (e.length < 2) return {}; + var i = e.split(""), + o = new Array(i.length), + u = new Array(i.length), + a = []; + s = r ? m : v, F(i, a, i.length, n); + for (var f = 0; f < o.length; o[f] = f, f++); + I(2, a, o), I(1, a, o); + for (var f = 0; f < o.length - 1; f++) n[f] === w ? a[f] = t.AN : a[f] === y && (n[f] > T && n[f] < O || n[f] === E || n[f] === H) ? a[f] = t.ON_R : f > 0 && i[f - 1] === "\u0644" && /\u0622|\u0623|\u0625|\u0627/.test(i[f]) && (a[f - 1] = a[f] = t.R_H, f++); + i[i.length - 1] === t.DOT && (a[i.length - 1] = t.B); + for (var f = 0; f < o.length; f++) u[f] = a[o[f]]; + return { + logicalFromVisual: o, + bidiLevels: u + } + }, t.hasBidiCharacters = function(e, t) { + var n = !1; + for (var r = 0; r < e.length; r++) t[r] = R(e.charAt(r)), !n && (t[r] == y || t[r] == T) && (n = !0); + return n + }, t.getVisualFromLogicalIdx = function(e, t) { + for (var n = 0; n < t.logicalFromVisual.length; n++) + if (t.logicalFromVisual[n] == e) return n; + return 0 + } +}), define("ace/bidihandler", ["require", "exports", "module", "ace/lib/bidiutil", "ace/lib/lang", "ace/lib/useragent"], function(e, t, n) { + "use strict"; + var r = e("./lib/bidiutil"), + i = e("./lib/lang"), + s = e("./lib/useragent"), + o = /[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac]/, + u = function(e) { + this.session = e, this.bidiMap = {}, this.currentRow = null, this.bidiUtil = r, this.charWidths = [], this.EOL = "\u00ac", this.showInvisibles = !0, this.isRtlDir = !1, this.line = "", this.wrapIndent = 0, this.isLastRow = !1, this.EOF = "\u00b6", this.seenBidi = !1 + }; + (function() { + this.isBidiRow = function(e, t, n) { + return this.seenBidi ? (e !== this.currentRow && (this.currentRow = e, this.updateRowLine(t, n), this.updateBidiMap()), this.bidiMap.bidiLevels) : !1 + }, this.onChange = function(e) { + this.seenBidi ? this.currentRow = null : e.action == "insert" && o.test(e.lines.join("\n")) && (this.seenBidi = !0, this.currentRow = null) + }, this.getDocumentRow = function() { + var e = 0, + t = this.session.$screenRowCache; + if (t.length) { + var n = this.session.$getRowCacheIndex(t, this.currentRow); + n >= 0 && (e = this.session.$docRowCache[n]) + } + return e + }, this.getSplitIndex = function() { + var e = 0, + t = this.session.$screenRowCache; + if (t.length) { + var n, r = this.session.$getRowCacheIndex(t, this.currentRow); + while (this.currentRow - e > 0) { + n = this.session.$getRowCacheIndex(t, this.currentRow - e - 1); + if (n !== r) break; + r = n, e++ + } + } + return e + }, this.updateRowLine = function(e, t) { + e === undefined && (e = this.getDocumentRow()), this.wrapIndent = 0, this.isLastRow = e === this.session.getLength() - 1, this.line = this.session.getLine(e); + if (this.session.$useWrapMode) { + var n = this.session.$wrapData[e]; + n && (t === undefined && (t = this.getSplitIndex()), t > 0 && n.length ? (this.wrapIndent = n.indent, this.line = t < n.length ? this.line.substring(n[t - 1], n[n.length - 1]) : this.line.substring(n[n.length - 1])) : this.line = this.line.substring(0, n[t])) + } + var s = this.session, + o = 0, + u; + this.line = this.line.replace(/\t|[\u1100-\u2029, \u202F-\uFFE6]/g, function(e, t) { + return e === " " || s.isFullWidth(e.charCodeAt(0)) ? (u = e === " " ? s.getScreenTabSize(t + o) : 2, o += u - 1, i.stringRepeat(r.DOT, u)) : e + }) + }, this.updateBidiMap = function() { + var e = [], + t = this.isLastRow ? this.EOF : this.EOL, + n = this.line + (this.showInvisibles ? t : r.DOT); + r.hasBidiCharacters(n, e) ? this.bidiMap = r.doBidiReorder(n, e, this.isRtlDir) : this.bidiMap = {} + }, this.markAsDirty = function() { + this.currentRow = null + }, this.updateCharacterWidths = function(e) { + if (!this.seenBidi) return; + if (this.characterWidth === e.$characterSize.width) return; + var t = this.characterWidth = e.$characterSize.width, + n = e.$measureCharWidth("\u05d4"); + this.charWidths[r.L] = this.charWidths[r.EN] = this.charWidths[r.ON_R] = t, this.charWidths[r.R] = this.charWidths[r.AN] = n, this.charWidths[r.R_H] = s.isChrome ? n : n * .45, this.charWidths[r.B] = 0, this.currentRow = null + }, this.getShowInvisibles = function() { + return this.showInvisibles + }, this.setShowInvisibles = function(e) { + this.showInvisibles = e, this.currentRow = null + }, this.setEolChar = function(e) { + this.EOL = e + }, this.setTextDir = function(e) { + this.isRtlDir = e + }, this.getPosLeft = function(e) { + e -= this.wrapIndent; + var t = r.getVisualFromLogicalIdx(e > 0 ? e - 1 : 0, this.bidiMap), + n = this.bidiMap.bidiLevels, + i = 0; + e === 0 && n[t] % 2 !== 0 && t++; + for (var s = 0; s < t; s++) i += this.charWidths[n[s]]; + return e !== 0 && n[t] % 2 === 0 && (i += this.charWidths[n[t]]), this.wrapIndent && (i += this.wrapIndent * this.charWidths[r.L]), i + }, this.getSelections = function(e, t) { + var n = this.bidiMap, + i = n.bidiLevels, + s, o = this.wrapIndent * this.charWidths[r.L], + u = [], + a = Math.min(e, t) - this.wrapIndent, + f = Math.max(e, t) - this.wrapIndent, + l = !1, + c = !1, + h = 0; + for (var p, d = 0; d < i.length; d++) p = n.logicalFromVisual[d], s = i[d], l = p >= a && p < f, l && !c ? h = o : !l && c && u.push({ + left: h, + width: o - h + }), o += this.charWidths[s], c = l; + return l && d === i.length && u.push({ + left: h, + width: o - h + }), u + }, this.offsetToCol = function(e) { + var t = 0, + e = Math.max(e, 0), + n = 0, + i = 0, + s = this.bidiMap.bidiLevels, + o = this.charWidths[s[i]]; + this.wrapIndent && (e -= this.wrapIndent * this.charWidths[r.L]); + while (e > n + o / 2) { + n += o; + if (i === s.length - 1) { + o = 0; + break + } + o = this.charWidths[s[++i]] + } + return i > 0 && s[i - 1] % 2 !== 0 && s[i] % 2 === 0 ? (e < n && i--, t = this.bidiMap.logicalFromVisual[i]) : i > 0 && s[i - 1] % 2 === 0 && s[i] % 2 !== 0 ? t = 1 + (e > n ? this.bidiMap.logicalFromVisual[i] : this.bidiMap.logicalFromVisual[i - 1]) : this.isRtlDir && i === s.length - 1 && o === 0 && s[i - 1] % 2 === 0 || !this.isRtlDir && i === 0 && s[i] % 2 !== 0 ? t = 1 + this.bidiMap.logicalFromVisual[i] : (i > 0 && s[i - 1] % 2 !== 0 && o !== 0 && i--, t = this.bidiMap.logicalFromVisual[i]), t + this.wrapIndent + } + }).call(u.prototype), t.BidiHandler = u +}), define("ace/range", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + var r = function(e, t) { + return e.row - t.row || e.column - t.column + }, + i = function(e, t, n, r) { + this.start = { + row: e, + column: t + }, this.end = { + row: n, + column: r + } + }; + (function() { + this.isEqual = function(e) { + return this.start.row === e.start.row && this.end.row === e.end.row && this.start.column === e.start.column && this.end.column === e.end.column + }, this.toString = function() { + return "Range: [" + this.start.row + "/" + this.start.column + "] -> [" + this.end.row + "/" + this.end.column + "]" + }, this.contains = function(e, t) { + return this.compare(e, t) == 0 + }, this.compareRange = function(e) { + var t, n = e.end, + r = e.start; + return t = this.compare(n.row, n.column), t == 1 ? (t = this.compare(r.row, r.column), t == 1 ? 2 : t == 0 ? 1 : 0) : t == -1 ? -2 : (t = this.compare(r.row, r.column), t == -1 ? -1 : t == 1 ? 42 : 0) + }, this.comparePoint = function(e) { + return this.compare(e.row, e.column) + }, this.containsRange = function(e) { + return this.comparePoint(e.start) == 0 && this.comparePoint(e.end) == 0 + }, this.intersects = function(e) { + var t = this.compareRange(e); + return t == -1 || t == 0 || t == 1 + }, this.isEnd = function(e, t) { + return this.end.row == e && this.end.column == t + }, this.isStart = function(e, t) { + return this.start.row == e && this.start.column == t + }, this.setStart = function(e, t) { + typeof e == "object" ? (this.start.column = e.column, this.start.row = e.row) : (this.start.row = e, this.start.column = t) + }, this.setEnd = function(e, t) { + typeof e == "object" ? (this.end.column = e.column, this.end.row = e.row) : (this.end.row = e, this.end.column = t) + }, this.inside = function(e, t) { + return this.compare(e, t) == 0 ? this.isEnd(e, t) || this.isStart(e, t) ? !1 : !0 : !1 + }, this.insideStart = function(e, t) { + return this.compare(e, t) == 0 ? this.isEnd(e, t) ? !1 : !0 : !1 + }, this.insideEnd = function(e, t) { + return this.compare(e, t) == 0 ? this.isStart(e, t) ? !1 : !0 : !1 + }, this.compare = function(e, t) { + return !this.isMultiLine() && e === this.start.row ? t < this.start.column ? -1 : t > this.end.column ? 1 : 0 : e < this.start.row ? -1 : e > this.end.row ? 1 : this.start.row === e ? t >= this.start.column ? 0 : -1 : this.end.row === e ? t <= this.end.column ? 0 : 1 : 0 + }, this.compareStart = function(e, t) { + return this.start.row == e && this.start.column == t ? -1 : this.compare(e, t) + }, this.compareEnd = function(e, t) { + return this.end.row == e && this.end.column == t ? 1 : this.compare(e, t) + }, this.compareInside = function(e, t) { + return this.end.row == e && this.end.column == t ? 1 : this.start.row == e && this.start.column == t ? -1 : this.compare(e, t) + }, this.clipRows = function(e, t) { + if (this.end.row > t) var n = { + row: t + 1, + column: 0 + }; + else if (this.end.row < e) var n = { + row: e, + column: 0 + }; + if (this.start.row > t) var r = { + row: t + 1, + column: 0 + }; + else if (this.start.row < e) var r = { + row: e, + column: 0 + }; + return i.fromPoints(r || this.start, n || this.end) + }, this.extend = function(e, t) { + var n = this.compare(e, t); + if (n == 0) return this; + if (n == -1) var r = { + row: e, + column: t + }; + else var s = { + row: e, + column: t + }; + return i.fromPoints(r || this.start, s || this.end) + }, this.isEmpty = function() { + return this.start.row === this.end.row && this.start.column === this.end.column + }, this.isMultiLine = function() { + return this.start.row !== this.end.row + }, this.clone = function() { + return i.fromPoints(this.start, this.end) + }, this.collapseRows = function() { + return this.end.column == 0 ? new i(this.start.row, 0, Math.max(this.start.row, this.end.row - 1), 0) : new i(this.start.row, 0, this.end.row, 0) + }, this.toScreenRange = function(e) { + var t = e.documentToScreenPosition(this.start), + n = e.documentToScreenPosition(this.end); + return new i(t.row, t.column, n.row, n.column) + }, this.moveBy = function(e, t) { + this.start.row += e, this.start.column += t, this.end.row += e, this.end.column += t + } + }).call(i.prototype), i.fromPoints = function(e, t) { + return new i(e.row, e.column, t.row, t.column) + }, i.comparePoints = r, i.comparePoints = function(e, t) { + return e.row - t.row || e.column - t.column + }, t.Range = i +}), define("ace/selection", ["require", "exports", "module", "ace/lib/oop", "ace/lib/lang", "ace/lib/event_emitter", "ace/range"], function(e, t, n) { + "use strict"; + var r = e("./lib/oop"), + i = e("./lib/lang"), + s = e("./lib/event_emitter").EventEmitter, + o = e("./range").Range, + u = function(e) { + this.session = e, this.doc = e.getDocument(), this.clearSelection(), this.lead = this.selectionLead = this.doc.createAnchor(0, 0), this.anchor = this.selectionAnchor = this.doc.createAnchor(0, 0); + var t = this; + this.lead.on("change", function(e) { + t._emit("changeCursor"), t.$isEmpty || t._emit("changeSelection"), !t.$keepDesiredColumnOnChange && e.old.column != e.value.column && (t.$desiredColumn = null) + }), this.selectionAnchor.on("change", function() { + t.$isEmpty || t._emit("changeSelection") + }) + }; + (function() { + r.implement(this, s), this.isEmpty = function() { + return this.$isEmpty || this.anchor.row == this.lead.row && this.anchor.column == this.lead.column + }, this.isMultiLine = function() { + return this.isEmpty() ? !1 : this.getRange().isMultiLine() + }, this.getCursor = function() { + return this.lead.getPosition() + }, this.setSelectionAnchor = function(e, t) { + this.anchor.setPosition(e, t), this.$isEmpty && (this.$isEmpty = !1, this._emit("changeSelection")) + }, this.getSelectionAnchor = function() { + return this.$isEmpty ? this.getSelectionLead() : this.anchor.getPosition() + }, this.getSelectionLead = function() { + return this.lead.getPosition() + }, this.shiftSelection = function(e) { + if (this.$isEmpty) { + this.moveCursorTo(this.lead.row, this.lead.column + e); + return + } + var t = this.getSelectionAnchor(), + n = this.getSelectionLead(), + r = this.isBackwards(); + (!r || t.column !== 0) && this.setSelectionAnchor(t.row, t.column + e), (r || n.column !== 0) && this.$moveSelection(function() { + this.moveCursorTo(n.row, n.column + e) + }) + }, this.isBackwards = function() { + var e = this.anchor, + t = this.lead; + return e.row > t.row || e.row == t.row && e.column > t.column + }, this.getRange = function() { + var e = this.anchor, + t = this.lead; + return this.isEmpty() ? o.fromPoints(t, t) : this.isBackwards() ? o.fromPoints(t, e) : o.fromPoints(e, t) + }, this.clearSelection = function() { + this.$isEmpty || (this.$isEmpty = !0, this._emit("changeSelection")) + }, this.selectAll = function() { + var e = this.doc.getLength() - 1; + this.setSelectionAnchor(0, 0), this.moveCursorTo(e, this.doc.getLine(e).length) + }, this.setRange = this.setSelectionRange = function(e, t) { + t ? (this.setSelectionAnchor(e.end.row, e.end.column), this.selectTo(e.start.row, e.start.column)) : (this.setSelectionAnchor(e.start.row, e.start.column), this.selectTo(e.end.row, e.end.column)), this.getRange().isEmpty() && (this.$isEmpty = !0), this.$desiredColumn = null + }, this.$moveSelection = function(e) { + var t = this.lead; + this.$isEmpty && this.setSelectionAnchor(t.row, t.column), e.call(this) + }, this.selectTo = function(e, t) { + this.$moveSelection(function() { + this.moveCursorTo(e, t) + }) + }, this.selectToPosition = function(e) { + this.$moveSelection(function() { + this.moveCursorToPosition(e) + }) + }, this.moveTo = function(e, t) { + this.clearSelection(), this.moveCursorTo(e, t) + }, this.moveToPosition = function(e) { + this.clearSelection(), this.moveCursorToPosition(e) + }, this.selectUp = function() { + this.$moveSelection(this.moveCursorUp) + }, this.selectDown = function() { + this.$moveSelection(this.moveCursorDown) + }, this.selectRight = function() { + this.$moveSelection(this.moveCursorRight) + }, this.selectLeft = function() { + this.$moveSelection(this.moveCursorLeft) + }, this.selectLineStart = function() { + this.$moveSelection(this.moveCursorLineStart) + }, this.selectLineEnd = function() { + this.$moveSelection(this.moveCursorLineEnd) + }, this.selectFileEnd = function() { + this.$moveSelection(this.moveCursorFileEnd) + }, this.selectFileStart = function() { + this.$moveSelection(this.moveCursorFileStart) + }, this.selectWordRight = function() { + this.$moveSelection(this.moveCursorWordRight) + }, this.selectWordLeft = function() { + this.$moveSelection(this.moveCursorWordLeft) + }, this.getWordRange = function(e, t) { + if (typeof t == "undefined") { + var n = e || this.lead; + e = n.row, t = n.column + } + return this.session.getWordRange(e, t) + }, this.selectWord = function() { + this.setSelectionRange(this.getWordRange()) + }, this.selectAWord = function() { + var e = this.getCursor(), + t = this.session.getAWordRange(e.row, e.column); + this.setSelectionRange(t) + }, this.getLineRange = function(e, t) { + var n = typeof e == "number" ? e : this.lead.row, + r, i = this.session.getFoldLine(n); + return i ? (n = i.start.row, r = i.end.row) : r = n, t === !0 ? new o(n, 0, r, this.session.getLine(r).length) : new o(n, 0, r + 1, 0) + }, this.selectLine = function() { + this.setSelectionRange(this.getLineRange()) + }, this.moveCursorUp = function() { + this.moveCursorBy(-1, 0) + }, this.moveCursorDown = function() { + this.moveCursorBy(1, 0) + }, this.wouldMoveIntoSoftTab = function(e, t, n) { + var r = e.column, + i = e.column + t; + return n < 0 && (r = e.column - t, i = e.column), this.session.isTabStop(e) && this.doc.getLine(e.row).slice(r, i).split(" ").length - 1 == t + }, this.moveCursorLeft = function() { + var e = this.lead.getPosition(), + t; + if (t = this.session.getFoldAt(e.row, e.column, -1)) this.moveCursorTo(t.start.row, t.start.column); + else if (e.column === 0) e.row > 0 && this.moveCursorTo(e.row - 1, this.doc.getLine(e.row - 1).length); + else { + var n = this.session.getTabSize(); + this.wouldMoveIntoSoftTab(e, n, -1) && !this.session.getNavigateWithinSoftTabs() ? this.moveCursorBy(0, -n) : this.moveCursorBy(0, -1) + } + }, this.moveCursorRight = function() { + var e = this.lead.getPosition(), + t; + if (t = this.session.getFoldAt(e.row, e.column, 1)) this.moveCursorTo(t.end.row, t.end.column); + else if (this.lead.column == this.doc.getLine(this.lead.row).length) this.lead.row < this.doc.getLength() - 1 && this.moveCursorTo(this.lead.row + 1, 0); + else { + var n = this.session.getTabSize(), + e = this.lead; + this.wouldMoveIntoSoftTab(e, n, 1) && !this.session.getNavigateWithinSoftTabs() ? this.moveCursorBy(0, n) : this.moveCursorBy(0, 1) + } + }, this.moveCursorLineStart = function() { + var e = this.lead.row, + t = this.lead.column, + n = this.session.documentToScreenRow(e, t), + r = this.session.screenToDocumentPosition(n, 0), + i = this.session.getDisplayLine(e, null, r.row, r.column), + s = i.match(/^\s*/); + s[0].length != t && !this.session.$useEmacsStyleLineStart && (r.column += s[0].length), this.moveCursorToPosition(r) + }, this.moveCursorLineEnd = function() { + var e = this.lead, + t = this.session.getDocumentLastRowColumnPosition(e.row, e.column); + if (this.lead.column == t.column) { + var n = this.session.getLine(t.row); + if (t.column == n.length) { + var r = n.search(/\s+$/); + r > 0 && (t.column = r) + } + } + this.moveCursorTo(t.row, t.column) + }, this.moveCursorFileEnd = function() { + var e = this.doc.getLength() - 1, + t = this.doc.getLine(e).length; + this.moveCursorTo(e, t) + }, this.moveCursorFileStart = function() { + this.moveCursorTo(0, 0) + }, this.moveCursorLongWordRight = function() { + var e = this.lead.row, + t = this.lead.column, + n = this.doc.getLine(e), + r = n.substring(t), + i; + this.session.nonTokenRe.lastIndex = 0, this.session.tokenRe.lastIndex = 0; + var s = this.session.getFoldAt(e, t, 1); + if (s) { + this.moveCursorTo(s.end.row, s.end.column); + return + } + if (i = this.session.nonTokenRe.exec(r)) t += this.session.nonTokenRe.lastIndex, this.session.nonTokenRe.lastIndex = 0, r = n.substring(t); + if (t >= n.length) { + this.moveCursorTo(e, n.length), this.moveCursorRight(), e < this.doc.getLength() - 1 && this.moveCursorWordRight(); + return + } + if (i = this.session.tokenRe.exec(r)) t += this.session.tokenRe.lastIndex, this.session.tokenRe.lastIndex = 0; + this.moveCursorTo(e, t) + }, this.moveCursorLongWordLeft = function() { + var e = this.lead.row, + t = this.lead.column, + n; + if (n = this.session.getFoldAt(e, t, -1)) { + this.moveCursorTo(n.start.row, n.start.column); + return + } + var r = this.session.getFoldStringAt(e, t, -1); + r == null && (r = this.doc.getLine(e).substring(0, t)); + var s = i.stringReverse(r), + o; + this.session.nonTokenRe.lastIndex = 0, this.session.tokenRe.lastIndex = 0; + if (o = this.session.nonTokenRe.exec(s)) t -= this.session.nonTokenRe.lastIndex, s = s.slice(this.session.nonTokenRe.lastIndex), this.session.nonTokenRe.lastIndex = 0; + if (t <= 0) { + this.moveCursorTo(e, 0), this.moveCursorLeft(), e > 0 && this.moveCursorWordLeft(); + return + } + if (o = this.session.tokenRe.exec(s)) t -= this.session.tokenRe.lastIndex, this.session.tokenRe.lastIndex = 0; + this.moveCursorTo(e, t) + }, this.$shortWordEndIndex = function(e) { + var t, n = 0, + r, i = /\s/, + s = this.session.tokenRe; + s.lastIndex = 0; + if (t = this.session.tokenRe.exec(e)) n = this.session.tokenRe.lastIndex; + else { + while ((r = e[n]) && i.test(r)) n++; + if (n < 1) { + s.lastIndex = 0; + while ((r = e[n]) && !s.test(r)) { + s.lastIndex = 0, n++; + if (i.test(r)) { + if (n > 2) { + n--; + break + } + while ((r = e[n]) && i.test(r)) n++; + if (n > 2) break + } + } + } + } + return s.lastIndex = 0, n + }, this.moveCursorShortWordRight = function() { + var e = this.lead.row, + t = this.lead.column, + n = this.doc.getLine(e), + r = n.substring(t), + i = this.session.getFoldAt(e, t, 1); + if (i) return this.moveCursorTo(i.end.row, i.end.column); + if (t == n.length) { + var s = this.doc.getLength(); + do e++, r = this.doc.getLine(e); while (e < s && /^\s*$/.test(r)); + /^\s+/.test(r) || (r = ""), t = 0 + } + var o = this.$shortWordEndIndex(r); + this.moveCursorTo(e, t + o) + }, this.moveCursorShortWordLeft = function() { + var e = this.lead.row, + t = this.lead.column, + n; + if (n = this.session.getFoldAt(e, t, -1)) return this.moveCursorTo(n.start.row, n.start.column); + var r = this.session.getLine(e).substring(0, t); + if (t === 0) { + do e--, r = this.doc.getLine(e); while (e > 0 && /^\s*$/.test(r)); + t = r.length, /\s+$/.test(r) || (r = "") + } + var s = i.stringReverse(r), + o = this.$shortWordEndIndex(s); + return this.moveCursorTo(e, t - o) + }, this.moveCursorWordRight = function() { + this.session.$selectLongWords ? this.moveCursorLongWordRight() : this.moveCursorShortWordRight() + }, this.moveCursorWordLeft = function() { + this.session.$selectLongWords ? this.moveCursorLongWordLeft() : this.moveCursorShortWordLeft() + }, this.moveCursorBy = function(e, t) { + var n = this.session.documentToScreenPosition(this.lead.row, this.lead.column), + r; + t === 0 && (e !== 0 && (this.session.$bidiHandler.isBidiRow(n.row, this.lead.row) ? (r = this.session.$bidiHandler.getPosLeft(n.column), n.column = Math.round(r / this.session.$bidiHandler.charWidths[0])) : r = n.column * this.session.$bidiHandler.charWidths[0]), this.$desiredColumn ? n.column = this.$desiredColumn : this.$desiredColumn = n.column); + var i = this.session.screenToDocumentPosition(n.row + e, n.column, r); + e !== 0 && t === 0 && i.row === this.lead.row && i.column === this.lead.column && this.session.lineWidgets && this.session.lineWidgets[i.row] && (i.row > 0 || e > 0) && i.row++, this.moveCursorTo(i.row, i.column + t, t === 0) + }, this.moveCursorToPosition = function(e) { + this.moveCursorTo(e.row, e.column) + }, this.moveCursorTo = function(e, t, n) { + var r = this.session.getFoldAt(e, t, 1); + r && (e = r.start.row, t = r.start.column), this.$keepDesiredColumnOnChange = !0; + var i = this.session.getLine(e); + /[\uDC00-\uDFFF]/.test(i.charAt(t)) && i.charAt(t - 1) && (this.lead.row == e && this.lead.column == t + 1 ? t -= 1 : t += 1), this.lead.setPosition(e, t), this.$keepDesiredColumnOnChange = !1, n || (this.$desiredColumn = null) + }, this.moveCursorToScreen = function(e, t, n) { + var r = this.session.screenToDocumentPosition(e, t); + this.moveCursorTo(r.row, r.column, n) + }, this.detach = function() { + this.lead.detach(), this.anchor.detach(), this.session = this.doc = null + }, this.fromOrientedRange = function(e) { + this.setSelectionRange(e, e.cursor == e.start), this.$desiredColumn = e.desiredColumn || this.$desiredColumn + }, this.toOrientedRange = function(e) { + var t = this.getRange(); + return e ? (e.start.column = t.start.column, e.start.row = t.start.row, e.end.column = t.end.column, e.end.row = t.end.row) : e = t, e.cursor = this.isBackwards() ? e.start : e.end, e.desiredColumn = this.$desiredColumn, e + }, this.getRangeOfMovements = function(e) { + var t = this.getCursor(); + try { + e(this); + var n = this.getCursor(); + return o.fromPoints(t, n) + } catch (r) { + return o.fromPoints(t, t) + } finally { + this.moveCursorToPosition(t) + } + }, this.toJSON = function() { + if (this.rangeCount) var e = this.ranges.map(function(e) { + var t = e.clone(); + return t.isBackwards = e.cursor == e.start, t + }); + else { + var e = this.getRange(); + e.isBackwards = this.isBackwards() + } + return e + }, this.fromJSON = function(e) { + if (e.start == undefined) { + if (this.rangeList) { + this.toSingleRange(e[0]); + for (var t = e.length; t--;) { + var n = o.fromPoints(e[t].start, e[t].end); + e[t].isBackwards && (n.cursor = n.start), this.addRange(n, !0) + } + return + } + e = e[0] + } + this.rangeList && this.toSingleRange(e), this.setSelectionRange(e, e.isBackwards) + }, this.isEqual = function(e) { + if ((e.length || this.rangeCount) && e.length != this.rangeCount) return !1; + if (!e.length || !this.ranges) return this.getRange().isEqual(e); + for (var t = this.ranges.length; t--;) + if (!this.ranges[t].isEqual(e[t])) return !1; + return !0 + } + }).call(u.prototype), t.Selection = u +}), define("ace/tokenizer", ["require", "exports", "module", "ace/config"], function(e, t, n) { + "use strict"; + var r = e("./config"), + i = 2e3, + s = function(e) { + this.states = e, this.regExps = {}, this.matchMappings = {}; + for (var t in this.states) { + var n = this.states[t], + r = [], + i = 0, + s = this.matchMappings[t] = { + defaultToken: "text" + }, + o = "g", + u = []; + for (var a = 0; a < n.length; a++) { + var f = n[a]; + f.defaultToken && (s.defaultToken = f.defaultToken), f.caseInsensitive && (o = "gi"); + if (f.regex == null) continue; + f.regex instanceof RegExp && (f.regex = f.regex.toString().slice(1, -1)); + var l = f.regex, + c = (new RegExp("(?:(" + l + ")|(.))")).exec("a").length - 2; + Array.isArray(f.token) ? f.token.length == 1 || c == 1 ? f.token = f.token[0] : c - 1 != f.token.length ? (this.reportError("number of classes and regexp groups doesn't match", { + rule: f, + groupCount: c - 1 + }), f.token = f.token[0]) : (f.tokenArray = f.token, f.token = null, f.onMatch = this.$arrayTokens) : typeof f.token == "function" && !f.onMatch && (c > 1 ? f.onMatch = this.$applyToken : f.onMatch = f.token), c > 1 && (/\\\d/.test(f.regex) ? l = f.regex.replace(/\\([0-9]+)/g, function(e, t) { + return "\\" + (parseInt(t, 10) + i + 1) + }) : (c = 1, l = this.removeCapturingGroups(f.regex)), !f.splitRegex && typeof f.token != "string" && u.push(f)), s[i] = a, i += c, r.push(l), f.onMatch || (f.onMatch = null) + } + r.length || (s[0] = 0, r.push("$")), u.forEach(function(e) { + e.splitRegex = this.createSplitterRegexp(e.regex, o) + }, this), this.regExps[t] = new RegExp("(" + r.join(")|(") + ")|($)", o) + } + }; + (function() { + this.$setMaxTokenCount = function(e) { + i = e | 0 + }, this.$applyToken = function(e) { + var t = this.splitRegex.exec(e).slice(1), + n = this.token.apply(this, t); + if (typeof n == "string") return [{ + type: n, + value: e + }]; + var r = []; + for (var i = 0, s = n.length; i < s; i++) t[i] && (r[r.length] = { + type: n[i], + value: t[i] + }); + return r + }, this.$arrayTokens = function(e) { + if (!e) return []; + var t = this.splitRegex.exec(e); + if (!t) return "text"; + var n = [], + r = this.tokenArray; + for (var i = 0, s = r.length; i < s; i++) t[i + 1] && (n[n.length] = { + type: r[i], + value: t[i + 1] + }); + return n + }, this.removeCapturingGroups = function(e) { + var t = e.replace(/\[(?:\\.|[^\]])*?\]|\\.|\(\?[:=!]|(\()/g, function(e, t) { + return t ? "(?:" : e + }); + return t + }, this.createSplitterRegexp = function(e, t) { + if (e.indexOf("(?=") != -1) { + var n = 0, + r = !1, + i = {}; + e.replace(/(\\.)|(\((?:\?[=!])?)|(\))|([\[\]])/g, function(e, t, s, o, u, a) { + return r ? r = u != "]" : u ? r = !0 : o ? (n == i.stack && (i.end = a + 1, i.stack = -1), n--) : s && (n++, s.length != 1 && (i.stack = n, i.start = a)), e + }), i.end != null && /^\)*$/.test(e.substr(i.end)) && (e = e.substring(0, i.start) + e.substr(i.end)) + } + return e.charAt(0) != "^" && (e = "^" + e), e.charAt(e.length - 1) != "$" && (e += "$"), new RegExp(e, (t || "").replace("g", "")) + }, this.getLineTokens = function(e, t) { + if (t && typeof t != "string") { + var n = t.slice(0); + t = n[0], t === "#tmp" && (n.shift(), t = n.shift()) + } else var n = []; + var r = t || "start", + s = this.states[r]; + s || (r = "start", s = this.states[r]); + var o = this.matchMappings[r], + u = this.regExps[r]; + u.lastIndex = 0; + var a, f = [], + l = 0, + c = 0, + h = { + type: null, + value: "" + }; + while (a = u.exec(e)) { + var p = o.defaultToken, + d = null, + v = a[0], + m = u.lastIndex; + if (m - v.length > l) { + var g = e.substring(l, m - v.length); + h.type == p ? h.value += g : (h.type && f.push(h), h = { + type: p, + value: g + }) + } + for (var y = 0; y < a.length - 2; y++) { + if (a[y + 1] === undefined) continue; + d = s[o[y]], d.onMatch ? p = d.onMatch(v, r, n, e) : p = d.token, d.next && (typeof d.next == "string" ? r = d.next : r = d.next(r, n), s = this.states[r], s || (this.reportError("state doesn't exist", r), r = "start", s = this.states[r]), o = this.matchMappings[r], l = m, u = this.regExps[r], u.lastIndex = m), d.consumeLineEnd && (l = m); + break + } + if (v) + if (typeof p == "string") !!d && d.merge === !1 || h.type !== p ? (h.type && f.push(h), h = { + type: p, + value: v + }) : h.value += v; + else if (p) { + h.type && f.push(h), h = { + type: null, + value: "" + }; + for (var y = 0; y < p.length; y++) f.push(p[y]) + } + if (l == e.length) break; + l = m; + if (c++ > i) { + c > 2 * e.length && this.reportError("infinite loop with in ace tokenizer", { + startState: t, + line: e + }); + while (l < e.length) h.type && f.push(h), h = { + value: e.substring(l, l += 2e3), + type: "overflow" + }; + r = "start", n = []; + break + } + } + return h.type && f.push(h), n.length > 1 && n[0] !== r && n.unshift("#tmp", r), { + tokens: f, + state: n.length ? n : r + } + }, this.reportError = r.reportError + }).call(s.prototype), t.Tokenizer = s +}), define("ace/mode/text_highlight_rules", ["require", "exports", "module", "ace/lib/lang"], function(e, t, n) { + "use strict"; + var r = e("../lib/lang"), + i = function() { + this.$rules = { + start: [{ + token: "empty_line", + regex: "^$" + }, { + defaultToken: "text" + }] + } + }; + (function() { + this.addRules = function(e, t) { + if (!t) { + for (var n in e) this.$rules[n] = e[n]; + return + } + for (var n in e) { + var r = e[n]; + for (var i = 0; i < r.length; i++) { + var s = r[i]; + if (s.next || s.onMatch) typeof s.next == "string" && s.next.indexOf(t) !== 0 && (s.next = t + s.next), s.nextState && s.nextState.indexOf(t) !== 0 && (s.nextState = t + s.nextState) + } + this.$rules[t + n] = r + } + }, this.getRules = function() { + return this.$rules + }, this.embedRules = function(e, t, n, i, s) { + var o = typeof e == "function" ? (new e).getRules() : e; + if (i) + for (var u = 0; u < i.length; u++) i[u] = t + i[u]; + else { + i = []; + for (var a in o) i.push(t + a) + } + this.addRules(o, t); + if (n) { + var f = Array.prototype[s ? "push" : "unshift"]; + for (var u = 0; u < i.length; u++) f.apply(this.$rules[i[u]], r.deepCopy(n)) + } + this.$embeds || (this.$embeds = []), this.$embeds.push(t) + }, this.getEmbeds = function() { + return this.$embeds + }; + var e = function(e, t) { + return (e != "start" || t.length) && t.unshift(this.nextState, e), this.nextState + }, + t = function(e, t) { + return t.shift(), t.shift() || "start" + }; + this.normalizeRules = function() { + function i(s) { + var o = r[s]; + o.processed = !0; + for (var u = 0; u < o.length; u++) { + var a = o[u], + f = null; + Array.isArray(a) && (f = a, a = {}), !a.regex && a.start && (a.regex = a.start, a.next || (a.next = []), a.next.push({ + defaultToken: a.token + }, { + token: a.token + ".end", + regex: a.end || a.start, + next: "pop" + }), a.token = a.token + ".start", a.push = !0); + var l = a.next || a.push; + if (l && Array.isArray(l)) { + var c = a.stateName; + c || (c = a.token, typeof c != "string" && (c = c[0] || ""), r[c] && (c += n++)), r[c] = l, a.next = c, i(c) + } else l == "pop" && (a.next = t); + a.push && (a.nextState = a.next || a.push, a.next = e, delete a.push); + if (a.rules) + for (var h in a.rules) r[h] ? r[h].push && r[h].push.apply(r[h], a.rules[h]) : r[h] = a.rules[h]; + var p = typeof a == "string" ? a : a.include; + p && (Array.isArray(p) ? f = p.map(function(e) { + return r[e] + }) : f = r[p]); + if (f) { + var d = [u, 1].concat(f); + a.noEscape && (d = d.filter(function(e) { + return !e.next + })), o.splice.apply(o, d), u-- + } + a.keywordMap && (a.token = this.createKeywordMapper(a.keywordMap, a.defaultToken || "text", a.caseInsensitive), delete a.defaultToken) + } + } + var n = 0, + r = this.$rules; + Object.keys(r).forEach(i, this) + }, this.createKeywordMapper = function(e, t, n, r) { + var i = Object.create(null); + return Object.keys(e).forEach(function(t) { + var s = e[t]; + n && (s = s.toLowerCase()); + var o = s.split(r || "|"); + for (var u = o.length; u--;) i[o[u]] = t + }), Object.getPrototypeOf(i) && (i.__proto__ = null), this.$keywordList = Object.keys(i), e = null, n ? function(e) { + return i[e.toLowerCase()] || t + } : function(e) { + return i[e] || t + } + }, this.getKeywords = function() { + return this.$keywords + } + }).call(i.prototype), t.TextHighlightRules = i +}), define("ace/mode/behaviour", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + var r = function() { + this.$behaviours = {} + }; + (function() { + this.add = function(e, t, n) { + switch (undefined) { + case this.$behaviours: + this.$behaviours = {}; + case this.$behaviours[e]: + this.$behaviours[e] = {} + } + this.$behaviours[e][t] = n + }, this.addBehaviours = function(e) { + for (var t in e) + for (var n in e[t]) this.add(t, n, e[t][n]) + }, this.remove = function(e) { + this.$behaviours && this.$behaviours[e] && delete this.$behaviours[e] + }, this.inherit = function(e, t) { + if (typeof e == "function") var n = (new e).getBehaviours(t); + else var n = e.getBehaviours(t); + this.addBehaviours(n) + }, this.getBehaviours = function(e) { + if (!e) return this.$behaviours; + var t = {}; + for (var n = 0; n < e.length; n++) this.$behaviours[e[n]] && (t[e[n]] = this.$behaviours[e[n]]); + return t + } + }).call(r.prototype), t.Behaviour = r +}), define("ace/token_iterator", ["require", "exports", "module", "ace/range"], function(e, t, n) { + "use strict"; + var r = e("./range").Range, + i = function(e, t, n) { + this.$session = e, this.$row = t, this.$rowTokens = e.getTokens(t); + var r = e.getTokenAt(t, n); + this.$tokenIndex = r ? r.index : -1 + }; + (function() { + this.stepBackward = function() { + this.$tokenIndex -= 1; + while (this.$tokenIndex < 0) { + this.$row -= 1; + if (this.$row < 0) return this.$row = 0, null; + this.$rowTokens = this.$session.getTokens(this.$row), this.$tokenIndex = this.$rowTokens.length - 1 + } + return this.$rowTokens[this.$tokenIndex] + }, this.stepForward = function() { + this.$tokenIndex += 1; + var e; + while (this.$tokenIndex >= this.$rowTokens.length) { + this.$row += 1, e || (e = this.$session.getLength()); + if (this.$row >= e) return this.$row = e - 1, null; + this.$rowTokens = this.$session.getTokens(this.$row), this.$tokenIndex = 0 + } + return this.$rowTokens[this.$tokenIndex] + }, this.getCurrentToken = function() { + return this.$rowTokens[this.$tokenIndex] + }, this.getCurrentTokenRow = function() { + return this.$row + }, this.getCurrentTokenColumn = function() { + var e = this.$rowTokens, + t = this.$tokenIndex, + n = e[t].start; + if (n !== undefined) return n; + n = 0; + while (t > 0) t -= 1, n += e[t].value.length; + return n + }, this.getCurrentTokenPosition = function() { + return { + row: this.$row, + column: this.getCurrentTokenColumn() + } + }, this.getCurrentTokenRange = function() { + var e = this.$rowTokens[this.$tokenIndex], + t = this.getCurrentTokenColumn(); + return new r(this.$row, t, this.$row, t + e.value.length) + } + }).call(i.prototype), t.TokenIterator = i +}), define("ace/mode/behaviour/cstyle", ["require", "exports", "module", "ace/lib/oop", "ace/mode/behaviour", "ace/token_iterator", "ace/lib/lang"], function(e, t, n) { + "use strict"; + var r = e("../../lib/oop"), + i = e("../behaviour").Behaviour, + s = e("../../token_iterator").TokenIterator, + o = e("../../lib/lang"), + u = ["text", "paren.rparen", "punctuation.operator"], + a = ["text", "paren.rparen", "punctuation.operator", "comment"], + f, l = {}, + c = { + '"': '"', + "'": "'" + }, + h = function(e) { + var t = -1; + e.multiSelect && (t = e.selection.index, l.rangeCount != e.multiSelect.rangeCount && (l = { + rangeCount: e.multiSelect.rangeCount + })); + if (l[t]) return f = l[t]; + f = l[t] = { + autoInsertedBrackets: 0, + autoInsertedRow: -1, + autoInsertedLineEnd: "", + maybeInsertedBrackets: 0, + maybeInsertedRow: -1, + maybeInsertedLineStart: "", + maybeInsertedLineEnd: "" + } + }, + p = function(e, t, n, r) { + var i = e.end.row - e.start.row; + return { + text: n + t + r, + selection: [0, e.start.column + 1, i, e.end.column + (i ? 0 : 1)] + } + }, + d = function(e) { + this.add("braces", "insertion", function(t, n, r, i, s) { + var u = r.getCursorPosition(), + a = i.doc.getLine(u.row); + if (s == "{") { + h(r); + var l = r.getSelectionRange(), + c = i.doc.getTextRange(l); + if (c !== "" && c !== "{" && r.getWrapBehavioursEnabled()) return p(l, c, "{", "}"); + if (d.isSaneInsertion(r, i)) return /[\]\}\)]/.test(a[u.column]) || r.inMultiSelectMode || e && e.braces ? (d.recordAutoInsert(r, i, "}"), { + text: "{}", + selection: [1, 1] + }) : (d.recordMaybeInsert(r, i, "{"), { + text: "{", + selection: [1, 1] + }) + } else if (s == "}") { + h(r); + var v = a.substring(u.column, u.column + 1); + if (v == "}") { + var m = i.$findOpeningBracket("}", { + column: u.column + 1, + row: u.row + }); + if (m !== null && d.isAutoInsertedClosing(u, a, s)) return d.popAutoInsertedClosing(), { + text: "", + selection: [1, 1] + } + } + } else { + if (s == "\n" || s == "\r\n") { + h(r); + var g = ""; + d.isMaybeInsertedClosing(u, a) && (g = o.stringRepeat("}", f.maybeInsertedBrackets), d.clearMaybeInsertedClosing()); + var v = a.substring(u.column, u.column + 1); + if (v === "}") { + var y = i.findMatchingBracket({ + row: u.row, + column: u.column + 1 + }, "}"); + if (!y) return null; + var b = this.$getIndent(i.getLine(y.row)) + } else { + if (!g) { + d.clearMaybeInsertedClosing(); + return + } + var b = this.$getIndent(a) + } + var w = b + i.getTabString(); + return { + text: "\n" + w + "\n" + b + g, + selection: [1, w.length, 1, w.length] + } + } + d.clearMaybeInsertedClosing() + } + }), this.add("braces", "deletion", function(e, t, n, r, i) { + var s = r.doc.getTextRange(i); + if (!i.isMultiLine() && s == "{") { + h(n); + var o = r.doc.getLine(i.start.row), + u = o.substring(i.end.column, i.end.column + 1); + if (u == "}") return i.end.column++, i; + f.maybeInsertedBrackets-- + } + }), this.add("parens", "insertion", function(e, t, n, r, i) { + if (i == "(") { + h(n); + var s = n.getSelectionRange(), + o = r.doc.getTextRange(s); + if (o !== "" && n.getWrapBehavioursEnabled()) return p(s, o, "(", ")"); + if (d.isSaneInsertion(n, r)) return d.recordAutoInsert(n, r, ")"), { + text: "()", + selection: [1, 1] + } + } else if (i == ")") { + h(n); + var u = n.getCursorPosition(), + a = r.doc.getLine(u.row), + f = a.substring(u.column, u.column + 1); + if (f == ")") { + var l = r.$findOpeningBracket(")", { + column: u.column + 1, + row: u.row + }); + if (l !== null && d.isAutoInsertedClosing(u, a, i)) return d.popAutoInsertedClosing(), { + text: "", + selection: [1, 1] + } + } + } + }), this.add("parens", "deletion", function(e, t, n, r, i) { + var s = r.doc.getTextRange(i); + if (!i.isMultiLine() && s == "(") { + h(n); + var o = r.doc.getLine(i.start.row), + u = o.substring(i.start.column + 1, i.start.column + 2); + if (u == ")") return i.end.column++, i + } + }), this.add("brackets", "insertion", function(e, t, n, r, i) { + if (i == "[") { + h(n); + var s = n.getSelectionRange(), + o = r.doc.getTextRange(s); + if (o !== "" && n.getWrapBehavioursEnabled()) return p(s, o, "[", "]"); + if (d.isSaneInsertion(n, r)) return d.recordAutoInsert(n, r, "]"), { + text: "[]", + selection: [1, 1] + } + } else if (i == "]") { + h(n); + var u = n.getCursorPosition(), + a = r.doc.getLine(u.row), + f = a.substring(u.column, u.column + 1); + if (f == "]") { + var l = r.$findOpeningBracket("]", { + column: u.column + 1, + row: u.row + }); + if (l !== null && d.isAutoInsertedClosing(u, a, i)) return d.popAutoInsertedClosing(), { + text: "", + selection: [1, 1] + } + } + } + }), this.add("brackets", "deletion", function(e, t, n, r, i) { + var s = r.doc.getTextRange(i); + if (!i.isMultiLine() && s == "[") { + h(n); + var o = r.doc.getLine(i.start.row), + u = o.substring(i.start.column + 1, i.start.column + 2); + if (u == "]") return i.end.column++, i + } + }), this.add("string_dquotes", "insertion", function(e, t, n, r, i) { + var s = r.$mode.$quotes || c; + if (i.length == 1 && s[i]) { + if (this.lineCommentStart && this.lineCommentStart.indexOf(i) != -1) return; + h(n); + var o = i, + u = n.getSelectionRange(), + a = r.doc.getTextRange(u); + if (a !== "" && (a.length != 1 || !s[a]) && n.getWrapBehavioursEnabled()) return p(u, a, o, o); + if (!a) { + var f = n.getCursorPosition(), + l = r.doc.getLine(f.row), + d = l.substring(f.column - 1, f.column), + v = l.substring(f.column, f.column + 1), + m = r.getTokenAt(f.row, f.column), + g = r.getTokenAt(f.row, f.column + 1); + if (d == "\\" && m && /escape/.test(m.type)) return null; + var y = m && /string|escape/.test(m.type), + b = !g || /string|escape/.test(g.type), + w; + if (v == o) w = y !== b, w && /string\.end/.test(g.type) && (w = !1); + else { + if (y && !b) return null; + if (y && b) return null; + var E = r.$mode.tokenRe; + E.lastIndex = 0; + var S = E.test(d); + E.lastIndex = 0; + var x = E.test(d); + if (S || x) return null; + if (v && !/[\s;,.})\]\\]/.test(v)) return null; + w = !0 + } + return { + text: w ? o + o : "", + selection: [1, 1] + } + } + } + }), this.add("string_dquotes", "deletion", function(e, t, n, r, i) { + var s = r.doc.getTextRange(i); + if (!i.isMultiLine() && (s == '"' || s == "'")) { + h(n); + var o = r.doc.getLine(i.start.row), + u = o.substring(i.start.column + 1, i.start.column + 2); + if (u == s) return i.end.column++, i + } + }) + }; + d.isSaneInsertion = function(e, t) { + var n = e.getCursorPosition(), + r = new s(t, n.row, n.column); + if (!this.$matchTokenType(r.getCurrentToken() || "text", u)) { + var i = new s(t, n.row, n.column + 1); + if (!this.$matchTokenType(i.getCurrentToken() || "text", u)) return !1 + } + return r.stepForward(), r.getCurrentTokenRow() !== n.row || this.$matchTokenType(r.getCurrentToken() || "text", a) + }, d.$matchTokenType = function(e, t) { + return t.indexOf(e.type || e) > -1 + }, d.recordAutoInsert = function(e, t, n) { + var r = e.getCursorPosition(), + i = t.doc.getLine(r.row); + this.isAutoInsertedClosing(r, i, f.autoInsertedLineEnd[0]) || (f.autoInsertedBrackets = 0), f.autoInsertedRow = r.row, f.autoInsertedLineEnd = n + i.substr(r.column), f.autoInsertedBrackets++ + }, d.recordMaybeInsert = function(e, t, n) { + var r = e.getCursorPosition(), + i = t.doc.getLine(r.row); + this.isMaybeInsertedClosing(r, i) || (f.maybeInsertedBrackets = 0), f.maybeInsertedRow = r.row, f.maybeInsertedLineStart = i.substr(0, r.column) + n, f.maybeInsertedLineEnd = i.substr(r.column), f.maybeInsertedBrackets++ + }, d.isAutoInsertedClosing = function(e, t, n) { + return f.autoInsertedBrackets > 0 && e.row === f.autoInsertedRow && n === f.autoInsertedLineEnd[0] && t.substr(e.column) === f.autoInsertedLineEnd + }, d.isMaybeInsertedClosing = function(e, t) { + return f.maybeInsertedBrackets > 0 && e.row === f.maybeInsertedRow && t.substr(e.column) === f.maybeInsertedLineEnd && t.substr(0, e.column) == f.maybeInsertedLineStart + }, d.popAutoInsertedClosing = function() { + f.autoInsertedLineEnd = f.autoInsertedLineEnd.substr(1), f.autoInsertedBrackets-- + }, d.clearMaybeInsertedClosing = function() { + f && (f.maybeInsertedBrackets = 0, f.maybeInsertedRow = -1) + }, r.inherits(d, i), t.CstyleBehaviour = d +}), define("ace/unicode", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + + function r(e) { + var n = /\w{4}/g; + for (var r in e) t.packages[r] = e[r].replace(n, "\\u$&") + } + t.packages = {}, r({ + L: "0041-005A0061-007A00AA00B500BA00C0-00D600D8-00F600F8-02C102C6-02D102E0-02E402EC02EE0370-037403760377037A-037D03860388-038A038C038E-03A103A3-03F503F7-0481048A-05250531-055605590561-058705D0-05EA05F0-05F20621-064A066E066F0671-06D306D506E506E606EE06EF06FA-06FC06FF07100712-072F074D-07A507B107CA-07EA07F407F507FA0800-0815081A082408280904-0939093D09500958-0961097109720979-097F0985-098C098F09900993-09A809AA-09B009B209B6-09B909BD09CE09DC09DD09DF-09E109F009F10A05-0A0A0A0F0A100A13-0A280A2A-0A300A320A330A350A360A380A390A59-0A5C0A5E0A72-0A740A85-0A8D0A8F-0A910A93-0AA80AAA-0AB00AB20AB30AB5-0AB90ABD0AD00AE00AE10B05-0B0C0B0F0B100B13-0B280B2A-0B300B320B330B35-0B390B3D0B5C0B5D0B5F-0B610B710B830B85-0B8A0B8E-0B900B92-0B950B990B9A0B9C0B9E0B9F0BA30BA40BA8-0BAA0BAE-0BB90BD00C05-0C0C0C0E-0C100C12-0C280C2A-0C330C35-0C390C3D0C580C590C600C610C85-0C8C0C8E-0C900C92-0CA80CAA-0CB30CB5-0CB90CBD0CDE0CE00CE10D05-0D0C0D0E-0D100D12-0D280D2A-0D390D3D0D600D610D7A-0D7F0D85-0D960D9A-0DB10DB3-0DBB0DBD0DC0-0DC60E01-0E300E320E330E40-0E460E810E820E840E870E880E8A0E8D0E94-0E970E99-0E9F0EA1-0EA30EA50EA70EAA0EAB0EAD-0EB00EB20EB30EBD0EC0-0EC40EC60EDC0EDD0F000F40-0F470F49-0F6C0F88-0F8B1000-102A103F1050-1055105A-105D106110651066106E-10701075-1081108E10A0-10C510D0-10FA10FC1100-1248124A-124D1250-12561258125A-125D1260-1288128A-128D1290-12B012B2-12B512B8-12BE12C012C2-12C512C8-12D612D8-13101312-13151318-135A1380-138F13A0-13F41401-166C166F-167F1681-169A16A0-16EA1700-170C170E-17111720-17311740-17511760-176C176E-17701780-17B317D717DC1820-18771880-18A818AA18B0-18F51900-191C1950-196D1970-19741980-19AB19C1-19C71A00-1A161A20-1A541AA71B05-1B331B45-1B4B1B83-1BA01BAE1BAF1C00-1C231C4D-1C4F1C5A-1C7D1CE9-1CEC1CEE-1CF11D00-1DBF1E00-1F151F18-1F1D1F20-1F451F48-1F4D1F50-1F571F591F5B1F5D1F5F-1F7D1F80-1FB41FB6-1FBC1FBE1FC2-1FC41FC6-1FCC1FD0-1FD31FD6-1FDB1FE0-1FEC1FF2-1FF41FF6-1FFC2071207F2090-209421022107210A-211321152119-211D212421262128212A-212D212F-2139213C-213F2145-2149214E218321842C00-2C2E2C30-2C5E2C60-2CE42CEB-2CEE2D00-2D252D30-2D652D6F2D80-2D962DA0-2DA62DA8-2DAE2DB0-2DB62DB8-2DBE2DC0-2DC62DC8-2DCE2DD0-2DD62DD8-2DDE2E2F300530063031-3035303B303C3041-3096309D-309F30A1-30FA30FC-30FF3105-312D3131-318E31A0-31B731F0-31FF3400-4DB54E00-9FCBA000-A48CA4D0-A4FDA500-A60CA610-A61FA62AA62BA640-A65FA662-A66EA67F-A697A6A0-A6E5A717-A71FA722-A788A78BA78CA7FB-A801A803-A805A807-A80AA80C-A822A840-A873A882-A8B3A8F2-A8F7A8FBA90A-A925A930-A946A960-A97CA984-A9B2A9CFAA00-AA28AA40-AA42AA44-AA4BAA60-AA76AA7AAA80-AAAFAAB1AAB5AAB6AAB9-AABDAAC0AAC2AADB-AADDABC0-ABE2AC00-D7A3D7B0-D7C6D7CB-D7FBF900-FA2DFA30-FA6DFA70-FAD9FB00-FB06FB13-FB17FB1DFB1F-FB28FB2A-FB36FB38-FB3CFB3EFB40FB41FB43FB44FB46-FBB1FBD3-FD3DFD50-FD8FFD92-FDC7FDF0-FDFBFE70-FE74FE76-FEFCFF21-FF3AFF41-FF5AFF66-FFBEFFC2-FFC7FFCA-FFCFFFD2-FFD7FFDA-FFDC", + Ll: "0061-007A00AA00B500BA00DF-00F600F8-00FF01010103010501070109010B010D010F01110113011501170119011B011D011F01210123012501270129012B012D012F01310133013501370138013A013C013E014001420144014601480149014B014D014F01510153015501570159015B015D015F01610163016501670169016B016D016F0171017301750177017A017C017E-0180018301850188018C018D019201950199-019B019E01A101A301A501A801AA01AB01AD01B001B401B601B901BA01BD-01BF01C601C901CC01CE01D001D201D401D601D801DA01DC01DD01DF01E101E301E501E701E901EB01ED01EF01F001F301F501F901FB01FD01FF02010203020502070209020B020D020F02110213021502170219021B021D021F02210223022502270229022B022D022F02310233-0239023C023F0240024202470249024B024D024F-02930295-02AF037103730377037B-037D039003AC-03CE03D003D103D5-03D703D903DB03DD03DF03E103E303E503E703E903EB03ED03EF-03F303F503F803FB03FC0430-045F04610463046504670469046B046D046F04710473047504770479047B047D047F0481048B048D048F04910493049504970499049B049D049F04A104A304A504A704A904AB04AD04AF04B104B304B504B704B904BB04BD04BF04C204C404C604C804CA04CC04CE04CF04D104D304D504D704D904DB04DD04DF04E104E304E504E704E904EB04ED04EF04F104F304F504F704F904FB04FD04FF05010503050505070509050B050D050F05110513051505170519051B051D051F0521052305250561-05871D00-1D2B1D62-1D771D79-1D9A1E011E031E051E071E091E0B1E0D1E0F1E111E131E151E171E191E1B1E1D1E1F1E211E231E251E271E291E2B1E2D1E2F1E311E331E351E371E391E3B1E3D1E3F1E411E431E451E471E491E4B1E4D1E4F1E511E531E551E571E591E5B1E5D1E5F1E611E631E651E671E691E6B1E6D1E6F1E711E731E751E771E791E7B1E7D1E7F1E811E831E851E871E891E8B1E8D1E8F1E911E931E95-1E9D1E9F1EA11EA31EA51EA71EA91EAB1EAD1EAF1EB11EB31EB51EB71EB91EBB1EBD1EBF1EC11EC31EC51EC71EC91ECB1ECD1ECF1ED11ED31ED51ED71ED91EDB1EDD1EDF1EE11EE31EE51EE71EE91EEB1EED1EEF1EF11EF31EF51EF71EF91EFB1EFD1EFF-1F071F10-1F151F20-1F271F30-1F371F40-1F451F50-1F571F60-1F671F70-1F7D1F80-1F871F90-1F971FA0-1FA71FB0-1FB41FB61FB71FBE1FC2-1FC41FC61FC71FD0-1FD31FD61FD71FE0-1FE71FF2-1FF41FF61FF7210A210E210F2113212F21342139213C213D2146-2149214E21842C30-2C5E2C612C652C662C682C6A2C6C2C712C732C742C76-2C7C2C812C832C852C872C892C8B2C8D2C8F2C912C932C952C972C992C9B2C9D2C9F2CA12CA32CA52CA72CA92CAB2CAD2CAF2CB12CB32CB52CB72CB92CBB2CBD2CBF2CC12CC32CC52CC72CC92CCB2CCD2CCF2CD12CD32CD52CD72CD92CDB2CDD2CDF2CE12CE32CE42CEC2CEE2D00-2D25A641A643A645A647A649A64BA64DA64FA651A653A655A657A659A65BA65DA65FA663A665A667A669A66BA66DA681A683A685A687A689A68BA68DA68FA691A693A695A697A723A725A727A729A72BA72DA72F-A731A733A735A737A739A73BA73DA73FA741A743A745A747A749A74BA74DA74FA751A753A755A757A759A75BA75DA75FA761A763A765A767A769A76BA76DA76FA771-A778A77AA77CA77FA781A783A785A787A78CFB00-FB06FB13-FB17FF41-FF5A", + Lu: "0041-005A00C0-00D600D8-00DE01000102010401060108010A010C010E01100112011401160118011A011C011E01200122012401260128012A012C012E01300132013401360139013B013D013F0141014301450147014A014C014E01500152015401560158015A015C015E01600162016401660168016A016C016E017001720174017601780179017B017D018101820184018601870189-018B018E-0191019301940196-0198019C019D019F01A001A201A401A601A701A901AC01AE01AF01B1-01B301B501B701B801BC01C401C701CA01CD01CF01D101D301D501D701D901DB01DE01E001E201E401E601E801EA01EC01EE01F101F401F6-01F801FA01FC01FE02000202020402060208020A020C020E02100212021402160218021A021C021E02200222022402260228022A022C022E02300232023A023B023D023E02410243-02460248024A024C024E03700372037603860388-038A038C038E038F0391-03A103A3-03AB03CF03D2-03D403D803DA03DC03DE03E003E203E403E603E803EA03EC03EE03F403F703F903FA03FD-042F04600462046404660468046A046C046E04700472047404760478047A047C047E0480048A048C048E04900492049404960498049A049C049E04A004A204A404A604A804AA04AC04AE04B004B204B404B604B804BA04BC04BE04C004C104C304C504C704C904CB04CD04D004D204D404D604D804DA04DC04DE04E004E204E404E604E804EA04EC04EE04F004F204F404F604F804FA04FC04FE05000502050405060508050A050C050E05100512051405160518051A051C051E0520052205240531-055610A0-10C51E001E021E041E061E081E0A1E0C1E0E1E101E121E141E161E181E1A1E1C1E1E1E201E221E241E261E281E2A1E2C1E2E1E301E321E341E361E381E3A1E3C1E3E1E401E421E441E461E481E4A1E4C1E4E1E501E521E541E561E581E5A1E5C1E5E1E601E621E641E661E681E6A1E6C1E6E1E701E721E741E761E781E7A1E7C1E7E1E801E821E841E861E881E8A1E8C1E8E1E901E921E941E9E1EA01EA21EA41EA61EA81EAA1EAC1EAE1EB01EB21EB41EB61EB81EBA1EBC1EBE1EC01EC21EC41EC61EC81ECA1ECC1ECE1ED01ED21ED41ED61ED81EDA1EDC1EDE1EE01EE21EE41EE61EE81EEA1EEC1EEE1EF01EF21EF41EF61EF81EFA1EFC1EFE1F08-1F0F1F18-1F1D1F28-1F2F1F38-1F3F1F48-1F4D1F591F5B1F5D1F5F1F68-1F6F1FB8-1FBB1FC8-1FCB1FD8-1FDB1FE8-1FEC1FF8-1FFB21022107210B-210D2110-211221152119-211D212421262128212A-212D2130-2133213E213F214521832C00-2C2E2C602C62-2C642C672C692C6B2C6D-2C702C722C752C7E-2C802C822C842C862C882C8A2C8C2C8E2C902C922C942C962C982C9A2C9C2C9E2CA02CA22CA42CA62CA82CAA2CAC2CAE2CB02CB22CB42CB62CB82CBA2CBC2CBE2CC02CC22CC42CC62CC82CCA2CCC2CCE2CD02CD22CD42CD62CD82CDA2CDC2CDE2CE02CE22CEB2CEDA640A642A644A646A648A64AA64CA64EA650A652A654A656A658A65AA65CA65EA662A664A666A668A66AA66CA680A682A684A686A688A68AA68CA68EA690A692A694A696A722A724A726A728A72AA72CA72EA732A734A736A738A73AA73CA73EA740A742A744A746A748A74AA74CA74EA750A752A754A756A758A75AA75CA75EA760A762A764A766A768A76AA76CA76EA779A77BA77DA77EA780A782A784A786A78BFF21-FF3A", + Lt: "01C501C801CB01F21F88-1F8F1F98-1F9F1FA8-1FAF1FBC1FCC1FFC", + Lm: "02B0-02C102C6-02D102E0-02E402EC02EE0374037A0559064006E506E607F407F507FA081A0824082809710E460EC610FC17D718431AA71C78-1C7D1D2C-1D611D781D9B-1DBF2071207F2090-20942C7D2D6F2E2F30053031-3035303B309D309E30FC-30FEA015A4F8-A4FDA60CA67FA717-A71FA770A788A9CFAA70AADDFF70FF9EFF9F", + Lo: "01BB01C0-01C3029405D0-05EA05F0-05F20621-063F0641-064A066E066F0671-06D306D506EE06EF06FA-06FC06FF07100712-072F074D-07A507B107CA-07EA0800-08150904-0939093D09500958-096109720979-097F0985-098C098F09900993-09A809AA-09B009B209B6-09B909BD09CE09DC09DD09DF-09E109F009F10A05-0A0A0A0F0A100A13-0A280A2A-0A300A320A330A350A360A380A390A59-0A5C0A5E0A72-0A740A85-0A8D0A8F-0A910A93-0AA80AAA-0AB00AB20AB30AB5-0AB90ABD0AD00AE00AE10B05-0B0C0B0F0B100B13-0B280B2A-0B300B320B330B35-0B390B3D0B5C0B5D0B5F-0B610B710B830B85-0B8A0B8E-0B900B92-0B950B990B9A0B9C0B9E0B9F0BA30BA40BA8-0BAA0BAE-0BB90BD00C05-0C0C0C0E-0C100C12-0C280C2A-0C330C35-0C390C3D0C580C590C600C610C85-0C8C0C8E-0C900C92-0CA80CAA-0CB30CB5-0CB90CBD0CDE0CE00CE10D05-0D0C0D0E-0D100D12-0D280D2A-0D390D3D0D600D610D7A-0D7F0D85-0D960D9A-0DB10DB3-0DBB0DBD0DC0-0DC60E01-0E300E320E330E40-0E450E810E820E840E870E880E8A0E8D0E94-0E970E99-0E9F0EA1-0EA30EA50EA70EAA0EAB0EAD-0EB00EB20EB30EBD0EC0-0EC40EDC0EDD0F000F40-0F470F49-0F6C0F88-0F8B1000-102A103F1050-1055105A-105D106110651066106E-10701075-1081108E10D0-10FA1100-1248124A-124D1250-12561258125A-125D1260-1288128A-128D1290-12B012B2-12B512B8-12BE12C012C2-12C512C8-12D612D8-13101312-13151318-135A1380-138F13A0-13F41401-166C166F-167F1681-169A16A0-16EA1700-170C170E-17111720-17311740-17511760-176C176E-17701780-17B317DC1820-18421844-18771880-18A818AA18B0-18F51900-191C1950-196D1970-19741980-19AB19C1-19C71A00-1A161A20-1A541B05-1B331B45-1B4B1B83-1BA01BAE1BAF1C00-1C231C4D-1C4F1C5A-1C771CE9-1CEC1CEE-1CF12135-21382D30-2D652D80-2D962DA0-2DA62DA8-2DAE2DB0-2DB62DB8-2DBE2DC0-2DC62DC8-2DCE2DD0-2DD62DD8-2DDE3006303C3041-3096309F30A1-30FA30FF3105-312D3131-318E31A0-31B731F0-31FF3400-4DB54E00-9FCBA000-A014A016-A48CA4D0-A4F7A500-A60BA610-A61FA62AA62BA66EA6A0-A6E5A7FB-A801A803-A805A807-A80AA80C-A822A840-A873A882-A8B3A8F2-A8F7A8FBA90A-A925A930-A946A960-A97CA984-A9B2AA00-AA28AA40-AA42AA44-AA4BAA60-AA6FAA71-AA76AA7AAA80-AAAFAAB1AAB5AAB6AAB9-AABDAAC0AAC2AADBAADCABC0-ABE2AC00-D7A3D7B0-D7C6D7CB-D7FBF900-FA2DFA30-FA6DFA70-FAD9FB1DFB1F-FB28FB2A-FB36FB38-FB3CFB3EFB40FB41FB43FB44FB46-FBB1FBD3-FD3DFD50-FD8FFD92-FDC7FDF0-FDFBFE70-FE74FE76-FEFCFF66-FF6FFF71-FF9DFFA0-FFBEFFC2-FFC7FFCA-FFCFFFD2-FFD7FFDA-FFDC", + M: "0300-036F0483-04890591-05BD05BF05C105C205C405C505C70610-061A064B-065E067006D6-06DC06DE-06E406E706E806EA-06ED07110730-074A07A6-07B007EB-07F30816-0819081B-08230825-08270829-082D0900-0903093C093E-094E0951-0955096209630981-098309BC09BE-09C409C709C809CB-09CD09D709E209E30A01-0A030A3C0A3E-0A420A470A480A4B-0A4D0A510A700A710A750A81-0A830ABC0ABE-0AC50AC7-0AC90ACB-0ACD0AE20AE30B01-0B030B3C0B3E-0B440B470B480B4B-0B4D0B560B570B620B630B820BBE-0BC20BC6-0BC80BCA-0BCD0BD70C01-0C030C3E-0C440C46-0C480C4A-0C4D0C550C560C620C630C820C830CBC0CBE-0CC40CC6-0CC80CCA-0CCD0CD50CD60CE20CE30D020D030D3E-0D440D46-0D480D4A-0D4D0D570D620D630D820D830DCA0DCF-0DD40DD60DD8-0DDF0DF20DF30E310E34-0E3A0E47-0E4E0EB10EB4-0EB90EBB0EBC0EC8-0ECD0F180F190F350F370F390F3E0F3F0F71-0F840F860F870F90-0F970F99-0FBC0FC6102B-103E1056-1059105E-10601062-10641067-106D1071-10741082-108D108F109A-109D135F1712-17141732-1734175217531772177317B6-17D317DD180B-180D18A91920-192B1930-193B19B0-19C019C819C91A17-1A1B1A55-1A5E1A60-1A7C1A7F1B00-1B041B34-1B441B6B-1B731B80-1B821BA1-1BAA1C24-1C371CD0-1CD21CD4-1CE81CED1CF21DC0-1DE61DFD-1DFF20D0-20F02CEF-2CF12DE0-2DFF302A-302F3099309AA66F-A672A67CA67DA6F0A6F1A802A806A80BA823-A827A880A881A8B4-A8C4A8E0-A8F1A926-A92DA947-A953A980-A983A9B3-A9C0AA29-AA36AA43AA4CAA4DAA7BAAB0AAB2-AAB4AAB7AAB8AABEAABFAAC1ABE3-ABEAABECABEDFB1EFE00-FE0FFE20-FE26", + Mn: "0300-036F0483-04870591-05BD05BF05C105C205C405C505C70610-061A064B-065E067006D6-06DC06DF-06E406E706E806EA-06ED07110730-074A07A6-07B007EB-07F30816-0819081B-08230825-08270829-082D0900-0902093C0941-0948094D0951-095509620963098109BC09C1-09C409CD09E209E30A010A020A3C0A410A420A470A480A4B-0A4D0A510A700A710A750A810A820ABC0AC1-0AC50AC70AC80ACD0AE20AE30B010B3C0B3F0B41-0B440B4D0B560B620B630B820BC00BCD0C3E-0C400C46-0C480C4A-0C4D0C550C560C620C630CBC0CBF0CC60CCC0CCD0CE20CE30D41-0D440D4D0D620D630DCA0DD2-0DD40DD60E310E34-0E3A0E47-0E4E0EB10EB4-0EB90EBB0EBC0EC8-0ECD0F180F190F350F370F390F71-0F7E0F80-0F840F860F870F90-0F970F99-0FBC0FC6102D-10301032-10371039103A103D103E10581059105E-10601071-1074108210851086108D109D135F1712-17141732-1734175217531772177317B7-17BD17C617C9-17D317DD180B-180D18A91920-19221927192819321939-193B1A171A181A561A58-1A5E1A601A621A65-1A6C1A73-1A7C1A7F1B00-1B031B341B36-1B3A1B3C1B421B6B-1B731B801B811BA2-1BA51BA81BA91C2C-1C331C361C371CD0-1CD21CD4-1CE01CE2-1CE81CED1DC0-1DE61DFD-1DFF20D0-20DC20E120E5-20F02CEF-2CF12DE0-2DFF302A-302F3099309AA66FA67CA67DA6F0A6F1A802A806A80BA825A826A8C4A8E0-A8F1A926-A92DA947-A951A980-A982A9B3A9B6-A9B9A9BCAA29-AA2EAA31AA32AA35AA36AA43AA4CAAB0AAB2-AAB4AAB7AAB8AABEAABFAAC1ABE5ABE8ABEDFB1EFE00-FE0FFE20-FE26", + Mc: "0903093E-09400949-094C094E0982098309BE-09C009C709C809CB09CC09D70A030A3E-0A400A830ABE-0AC00AC90ACB0ACC0B020B030B3E0B400B470B480B4B0B4C0B570BBE0BBF0BC10BC20BC6-0BC80BCA-0BCC0BD70C01-0C030C41-0C440C820C830CBE0CC0-0CC40CC70CC80CCA0CCB0CD50CD60D020D030D3E-0D400D46-0D480D4A-0D4C0D570D820D830DCF-0DD10DD8-0DDF0DF20DF30F3E0F3F0F7F102B102C10311038103B103C105610571062-10641067-106D108310841087-108C108F109A-109C17B617BE-17C517C717C81923-19261929-192B193019311933-193819B0-19C019C819C91A19-1A1B1A551A571A611A631A641A6D-1A721B041B351B3B1B3D-1B411B431B441B821BA11BA61BA71BAA1C24-1C2B1C341C351CE11CF2A823A824A827A880A881A8B4-A8C3A952A953A983A9B4A9B5A9BAA9BBA9BD-A9C0AA2FAA30AA33AA34AA4DAA7BABE3ABE4ABE6ABE7ABE9ABEAABEC", + Me: "0488048906DE20DD-20E020E2-20E4A670-A672", + N: "0030-003900B200B300B900BC-00BE0660-066906F0-06F907C0-07C90966-096F09E6-09EF09F4-09F90A66-0A6F0AE6-0AEF0B66-0B6F0BE6-0BF20C66-0C6F0C78-0C7E0CE6-0CEF0D66-0D750E50-0E590ED0-0ED90F20-0F331040-10491090-10991369-137C16EE-16F017E0-17E917F0-17F91810-18191946-194F19D0-19DA1A80-1A891A90-1A991B50-1B591BB0-1BB91C40-1C491C50-1C5920702074-20792080-20892150-21822185-21892460-249B24EA-24FF2776-27932CFD30073021-30293038-303A3192-31953220-32293251-325F3280-328932B1-32BFA620-A629A6E6-A6EFA830-A835A8D0-A8D9A900-A909A9D0-A9D9AA50-AA59ABF0-ABF9FF10-FF19", + Nd: "0030-00390660-066906F0-06F907C0-07C90966-096F09E6-09EF0A66-0A6F0AE6-0AEF0B66-0B6F0BE6-0BEF0C66-0C6F0CE6-0CEF0D66-0D6F0E50-0E590ED0-0ED90F20-0F291040-10491090-109917E0-17E91810-18191946-194F19D0-19DA1A80-1A891A90-1A991B50-1B591BB0-1BB91C40-1C491C50-1C59A620-A629A8D0-A8D9A900-A909A9D0-A9D9AA50-AA59ABF0-ABF9FF10-FF19", + Nl: "16EE-16F02160-21822185-218830073021-30293038-303AA6E6-A6EF", + No: "00B200B300B900BC-00BE09F4-09F90BF0-0BF20C78-0C7E0D70-0D750F2A-0F331369-137C17F0-17F920702074-20792080-20892150-215F21892460-249B24EA-24FF2776-27932CFD3192-31953220-32293251-325F3280-328932B1-32BFA830-A835", + P: "0021-00230025-002A002C-002F003A003B003F0040005B-005D005F007B007D00A100AB00B700BB00BF037E0387055A-055F0589058A05BE05C005C305C605F305F40609060A060C060D061B061E061F066A-066D06D40700-070D07F7-07F90830-083E0964096509700DF40E4F0E5A0E5B0F04-0F120F3A-0F3D0F850FD0-0FD4104A-104F10FB1361-13681400166D166E169B169C16EB-16ED1735173617D4-17D617D8-17DA1800-180A1944194519DE19DF1A1E1A1F1AA0-1AA61AA8-1AAD1B5A-1B601C3B-1C3F1C7E1C7F1CD32010-20272030-20432045-20512053-205E207D207E208D208E2329232A2768-277527C527C627E6-27EF2983-299829D8-29DB29FC29FD2CF9-2CFC2CFE2CFF2E00-2E2E2E302E313001-30033008-30113014-301F3030303D30A030FBA4FEA4FFA60D-A60FA673A67EA6F2-A6F7A874-A877A8CEA8CFA8F8-A8FAA92EA92FA95FA9C1-A9CDA9DEA9DFAA5C-AA5FAADEAADFABEBFD3EFD3FFE10-FE19FE30-FE52FE54-FE61FE63FE68FE6AFE6BFF01-FF03FF05-FF0AFF0C-FF0FFF1AFF1BFF1FFF20FF3B-FF3DFF3FFF5BFF5DFF5F-FF65", + Pd: "002D058A05BE140018062010-20152E172E1A301C303030A0FE31FE32FE58FE63FF0D", + Ps: "0028005B007B0F3A0F3C169B201A201E2045207D208D23292768276A276C276E27702772277427C527E627E827EA27EC27EE2983298529872989298B298D298F299129932995299729D829DA29FC2E222E242E262E283008300A300C300E3010301430163018301A301DFD3EFE17FE35FE37FE39FE3BFE3DFE3FFE41FE43FE47FE59FE5BFE5DFF08FF3BFF5BFF5FFF62", + Pe: "0029005D007D0F3B0F3D169C2046207E208E232A2769276B276D276F27712773277527C627E727E927EB27ED27EF298429862988298A298C298E2990299229942996299829D929DB29FD2E232E252E272E293009300B300D300F3011301530173019301B301E301FFD3FFE18FE36FE38FE3AFE3CFE3EFE40FE42FE44FE48FE5AFE5CFE5EFF09FF3DFF5DFF60FF63", + Pi: "00AB2018201B201C201F20392E022E042E092E0C2E1C2E20", + Pf: "00BB2019201D203A2E032E052E0A2E0D2E1D2E21", + Pc: "005F203F20402054FE33FE34FE4D-FE4FFF3F", + Po: "0021-00230025-0027002A002C002E002F003A003B003F0040005C00A100B700BF037E0387055A-055F058905C005C305C605F305F40609060A060C060D061B061E061F066A-066D06D40700-070D07F7-07F90830-083E0964096509700DF40E4F0E5A0E5B0F04-0F120F850FD0-0FD4104A-104F10FB1361-1368166D166E16EB-16ED1735173617D4-17D617D8-17DA1800-18051807-180A1944194519DE19DF1A1E1A1F1AA0-1AA61AA8-1AAD1B5A-1B601C3B-1C3F1C7E1C7F1CD3201620172020-20272030-2038203B-203E2041-20432047-205120532055-205E2CF9-2CFC2CFE2CFF2E002E012E06-2E082E0B2E0E-2E162E182E192E1B2E1E2E1F2E2A-2E2E2E302E313001-3003303D30FBA4FEA4FFA60D-A60FA673A67EA6F2-A6F7A874-A877A8CEA8CFA8F8-A8FAA92EA92FA95FA9C1-A9CDA9DEA9DFAA5C-AA5FAADEAADFABEBFE10-FE16FE19FE30FE45FE46FE49-FE4CFE50-FE52FE54-FE57FE5F-FE61FE68FE6AFE6BFF01-FF03FF05-FF07FF0AFF0CFF0EFF0FFF1AFF1BFF1FFF20FF3CFF61FF64FF65", + S: "0024002B003C-003E005E0060007C007E00A2-00A900AC00AE-00B100B400B600B800D700F702C2-02C502D2-02DF02E5-02EB02ED02EF-02FF03750384038503F604820606-0608060B060E060F06E906FD06FE07F609F209F309FA09FB0AF10B700BF3-0BFA0C7F0CF10CF20D790E3F0F01-0F030F13-0F170F1A-0F1F0F340F360F380FBE-0FC50FC7-0FCC0FCE0FCF0FD5-0FD8109E109F13601390-139917DB194019E0-19FF1B61-1B6A1B74-1B7C1FBD1FBF-1FC11FCD-1FCF1FDD-1FDF1FED-1FEF1FFD1FFE20442052207A-207C208A-208C20A0-20B8210021012103-21062108210921142116-2118211E-2123212521272129212E213A213B2140-2144214A-214D214F2190-2328232B-23E82400-24262440-244A249C-24E92500-26CD26CF-26E126E326E8-26FF2701-27042706-2709270C-27272729-274B274D274F-27522756-275E2761-276727942798-27AF27B1-27BE27C0-27C427C7-27CA27CC27D0-27E527F0-29822999-29D729DC-29FB29FE-2B4C2B50-2B592CE5-2CEA2E80-2E992E9B-2EF32F00-2FD52FF0-2FFB300430123013302030363037303E303F309B309C319031913196-319F31C0-31E33200-321E322A-32503260-327F328A-32B032C0-32FE3300-33FF4DC0-4DFFA490-A4C6A700-A716A720A721A789A78AA828-A82BA836-A839AA77-AA79FB29FDFCFDFDFE62FE64-FE66FE69FF04FF0BFF1C-FF1EFF3EFF40FF5CFF5EFFE0-FFE6FFE8-FFEEFFFCFFFD", + Sm: "002B003C-003E007C007E00AC00B100D700F703F60606-060820442052207A-207C208A-208C2140-2144214B2190-2194219A219B21A021A321A621AE21CE21CF21D221D421F4-22FF2308-230B23202321237C239B-23B323DC-23E125B725C125F8-25FF266F27C0-27C427C7-27CA27CC27D0-27E527F0-27FF2900-29822999-29D729DC-29FB29FE-2AFF2B30-2B442B47-2B4CFB29FE62FE64-FE66FF0BFF1C-FF1EFF5CFF5EFFE2FFE9-FFEC", + Sc: "002400A2-00A5060B09F209F309FB0AF10BF90E3F17DB20A0-20B8A838FDFCFE69FF04FFE0FFE1FFE5FFE6", + Sk: "005E006000A800AF00B400B802C2-02C502D2-02DF02E5-02EB02ED02EF-02FF0375038403851FBD1FBF-1FC11FCD-1FCF1FDD-1FDF1FED-1FEF1FFD1FFE309B309CA700-A716A720A721A789A78AFF3EFF40FFE3", + So: "00A600A700A900AE00B000B60482060E060F06E906FD06FE07F609FA0B700BF3-0BF80BFA0C7F0CF10CF20D790F01-0F030F13-0F170F1A-0F1F0F340F360F380FBE-0FC50FC7-0FCC0FCE0FCF0FD5-0FD8109E109F13601390-1399194019E0-19FF1B61-1B6A1B74-1B7C210021012103-21062108210921142116-2118211E-2123212521272129212E213A213B214A214C214D214F2195-2199219C-219F21A121A221A421A521A7-21AD21AF-21CD21D021D121D321D5-21F32300-2307230C-231F2322-2328232B-237B237D-239A23B4-23DB23E2-23E82400-24262440-244A249C-24E92500-25B625B8-25C025C2-25F72600-266E2670-26CD26CF-26E126E326E8-26FF2701-27042706-2709270C-27272729-274B274D274F-27522756-275E2761-276727942798-27AF27B1-27BE2800-28FF2B00-2B2F2B452B462B50-2B592CE5-2CEA2E80-2E992E9B-2EF32F00-2FD52FF0-2FFB300430123013302030363037303E303F319031913196-319F31C0-31E33200-321E322A-32503260-327F328A-32B032C0-32FE3300-33FF4DC0-4DFFA490-A4C6A828-A82BA836A837A839AA77-AA79FDFDFFE4FFE8FFEDFFEEFFFCFFFD", + Z: "002000A01680180E2000-200A20282029202F205F3000", + Zs: "002000A01680180E2000-200A202F205F3000", + Zl: "2028", + Zp: "2029", + C: "0000-001F007F-009F00AD03780379037F-0383038B038D03A20526-05300557055805600588058B-059005C8-05CF05EB-05EF05F5-0605061C061D0620065F06DD070E070F074B074C07B2-07BF07FB-07FF082E082F083F-08FF093A093B094F095609570973-097809800984098D098E0991099209A909B109B3-09B509BA09BB09C509C609C909CA09CF-09D609D8-09DB09DE09E409E509FC-0A000A040A0B-0A0E0A110A120A290A310A340A370A3A0A3B0A3D0A43-0A460A490A4A0A4E-0A500A52-0A580A5D0A5F-0A650A76-0A800A840A8E0A920AA90AB10AB40ABA0ABB0AC60ACA0ACE0ACF0AD1-0ADF0AE40AE50AF00AF2-0B000B040B0D0B0E0B110B120B290B310B340B3A0B3B0B450B460B490B4A0B4E-0B550B58-0B5B0B5E0B640B650B72-0B810B840B8B-0B8D0B910B96-0B980B9B0B9D0BA0-0BA20BA5-0BA70BAB-0BAD0BBA-0BBD0BC3-0BC50BC90BCE0BCF0BD1-0BD60BD8-0BE50BFB-0C000C040C0D0C110C290C340C3A-0C3C0C450C490C4E-0C540C570C5A-0C5F0C640C650C70-0C770C800C810C840C8D0C910CA90CB40CBA0CBB0CC50CC90CCE-0CD40CD7-0CDD0CDF0CE40CE50CF00CF3-0D010D040D0D0D110D290D3A-0D3C0D450D490D4E-0D560D58-0D5F0D640D650D76-0D780D800D810D840D97-0D990DB20DBC0DBE0DBF0DC7-0DC90DCB-0DCE0DD50DD70DE0-0DF10DF5-0E000E3B-0E3E0E5C-0E800E830E850E860E890E8B0E8C0E8E-0E930E980EA00EA40EA60EA80EA90EAC0EBA0EBE0EBF0EC50EC70ECE0ECF0EDA0EDB0EDE-0EFF0F480F6D-0F700F8C-0F8F0F980FBD0FCD0FD9-0FFF10C6-10CF10FD-10FF1249124E124F12571259125E125F1289128E128F12B112B612B712BF12C112C612C712D7131113161317135B-135E137D-137F139A-139F13F5-13FF169D-169F16F1-16FF170D1715-171F1737-173F1754-175F176D17711774-177F17B417B517DE17DF17EA-17EF17FA-17FF180F181A-181F1878-187F18AB-18AF18F6-18FF191D-191F192C-192F193C-193F1941-1943196E196F1975-197F19AC-19AF19CA-19CF19DB-19DD1A1C1A1D1A5F1A7D1A7E1A8A-1A8F1A9A-1A9F1AAE-1AFF1B4C-1B4F1B7D-1B7F1BAB-1BAD1BBA-1BFF1C38-1C3A1C4A-1C4C1C80-1CCF1CF3-1CFF1DE7-1DFC1F161F171F1E1F1F1F461F471F4E1F4F1F581F5A1F5C1F5E1F7E1F7F1FB51FC51FD41FD51FDC1FF01FF11FF51FFF200B-200F202A-202E2060-206F20722073208F2095-209F20B9-20CF20F1-20FF218A-218F23E9-23FF2427-243F244B-245F26CE26E226E4-26E727002705270A270B2728274C274E2753-2755275F27602795-279727B027BF27CB27CD-27CF2B4D-2B4F2B5A-2BFF2C2F2C5F2CF2-2CF82D26-2D2F2D66-2D6E2D70-2D7F2D97-2D9F2DA72DAF2DB72DBF2DC72DCF2DD72DDF2E32-2E7F2E9A2EF4-2EFF2FD6-2FEF2FFC-2FFF3040309730983100-3104312E-3130318F31B8-31BF31E4-31EF321F32FF4DB6-4DBF9FCC-9FFFA48D-A48FA4C7-A4CFA62C-A63FA660A661A674-A67BA698-A69FA6F8-A6FFA78D-A7FAA82C-A82FA83A-A83FA878-A87FA8C5-A8CDA8DA-A8DFA8FC-A8FFA954-A95EA97D-A97FA9CEA9DA-A9DDA9E0-A9FFAA37-AA3FAA4EAA4FAA5AAA5BAA7C-AA7FAAC3-AADAAAE0-ABBFABEEABEFABFA-ABFFD7A4-D7AFD7C7-D7CAD7FC-F8FFFA2EFA2FFA6EFA6FFADA-FAFFFB07-FB12FB18-FB1CFB37FB3DFB3FFB42FB45FBB2-FBD2FD40-FD4FFD90FD91FDC8-FDEFFDFEFDFFFE1A-FE1FFE27-FE2FFE53FE67FE6C-FE6FFE75FEFD-FF00FFBF-FFC1FFC8FFC9FFD0FFD1FFD8FFD9FFDD-FFDFFFE7FFEF-FFFBFFFEFFFF", + Cc: "0000-001F007F-009F", + Cf: "00AD0600-060306DD070F17B417B5200B-200F202A-202E2060-2064206A-206FFEFFFFF9-FFFB", + Co: "E000-F8FF", + Cs: "D800-DFFF", + Cn: "03780379037F-0383038B038D03A20526-05300557055805600588058B-059005C8-05CF05EB-05EF05F5-05FF06040605061C061D0620065F070E074B074C07B2-07BF07FB-07FF082E082F083F-08FF093A093B094F095609570973-097809800984098D098E0991099209A909B109B3-09B509BA09BB09C509C609C909CA09CF-09D609D8-09DB09DE09E409E509FC-0A000A040A0B-0A0E0A110A120A290A310A340A370A3A0A3B0A3D0A43-0A460A490A4A0A4E-0A500A52-0A580A5D0A5F-0A650A76-0A800A840A8E0A920AA90AB10AB40ABA0ABB0AC60ACA0ACE0ACF0AD1-0ADF0AE40AE50AF00AF2-0B000B040B0D0B0E0B110B120B290B310B340B3A0B3B0B450B460B490B4A0B4E-0B550B58-0B5B0B5E0B640B650B72-0B810B840B8B-0B8D0B910B96-0B980B9B0B9D0BA0-0BA20BA5-0BA70BAB-0BAD0BBA-0BBD0BC3-0BC50BC90BCE0BCF0BD1-0BD60BD8-0BE50BFB-0C000C040C0D0C110C290C340C3A-0C3C0C450C490C4E-0C540C570C5A-0C5F0C640C650C70-0C770C800C810C840C8D0C910CA90CB40CBA0CBB0CC50CC90CCE-0CD40CD7-0CDD0CDF0CE40CE50CF00CF3-0D010D040D0D0D110D290D3A-0D3C0D450D490D4E-0D560D58-0D5F0D640D650D76-0D780D800D810D840D97-0D990DB20DBC0DBE0DBF0DC7-0DC90DCB-0DCE0DD50DD70DE0-0DF10DF5-0E000E3B-0E3E0E5C-0E800E830E850E860E890E8B0E8C0E8E-0E930E980EA00EA40EA60EA80EA90EAC0EBA0EBE0EBF0EC50EC70ECE0ECF0EDA0EDB0EDE-0EFF0F480F6D-0F700F8C-0F8F0F980FBD0FCD0FD9-0FFF10C6-10CF10FD-10FF1249124E124F12571259125E125F1289128E128F12B112B612B712BF12C112C612C712D7131113161317135B-135E137D-137F139A-139F13F5-13FF169D-169F16F1-16FF170D1715-171F1737-173F1754-175F176D17711774-177F17DE17DF17EA-17EF17FA-17FF180F181A-181F1878-187F18AB-18AF18F6-18FF191D-191F192C-192F193C-193F1941-1943196E196F1975-197F19AC-19AF19CA-19CF19DB-19DD1A1C1A1D1A5F1A7D1A7E1A8A-1A8F1A9A-1A9F1AAE-1AFF1B4C-1B4F1B7D-1B7F1BAB-1BAD1BBA-1BFF1C38-1C3A1C4A-1C4C1C80-1CCF1CF3-1CFF1DE7-1DFC1F161F171F1E1F1F1F461F471F4E1F4F1F581F5A1F5C1F5E1F7E1F7F1FB51FC51FD41FD51FDC1FF01FF11FF51FFF2065-206920722073208F2095-209F20B9-20CF20F1-20FF218A-218F23E9-23FF2427-243F244B-245F26CE26E226E4-26E727002705270A270B2728274C274E2753-2755275F27602795-279727B027BF27CB27CD-27CF2B4D-2B4F2B5A-2BFF2C2F2C5F2CF2-2CF82D26-2D2F2D66-2D6E2D70-2D7F2D97-2D9F2DA72DAF2DB72DBF2DC72DCF2DD72DDF2E32-2E7F2E9A2EF4-2EFF2FD6-2FEF2FFC-2FFF3040309730983100-3104312E-3130318F31B8-31BF31E4-31EF321F32FF4DB6-4DBF9FCC-9FFFA48D-A48FA4C7-A4CFA62C-A63FA660A661A674-A67BA698-A69FA6F8-A6FFA78D-A7FAA82C-A82FA83A-A83FA878-A87FA8C5-A8CDA8DA-A8DFA8FC-A8FFA954-A95EA97D-A97FA9CEA9DA-A9DDA9E0-A9FFAA37-AA3FAA4EAA4FAA5AAA5BAA7C-AA7FAAC3-AADAAAE0-ABBFABEEABEFABFA-ABFFD7A4-D7AFD7C7-D7CAD7FC-D7FFFA2EFA2FFA6EFA6FFADA-FAFFFB07-FB12FB18-FB1CFB37FB3DFB3FFB42FB45FBB2-FBD2FD40-FD4FFD90FD91FDC8-FDEFFDFEFDFFFE1A-FE1FFE27-FE2FFE53FE67FE6C-FE6FFE75FEFDFEFEFF00FFBF-FFC1FFC8FFC9FFD0FFD1FFD8FFD9FFDD-FFDFFFE7FFEF-FFF8FFFEFFFF" + }) +}), define("ace/mode/text", ["require", "exports", "module", "ace/tokenizer", "ace/mode/text_highlight_rules", "ace/mode/behaviour/cstyle", "ace/unicode", "ace/lib/lang", "ace/token_iterator", "ace/range"], function(e, t, n) { + "use strict"; + var r = e("../tokenizer").Tokenizer, + i = e("./text_highlight_rules").TextHighlightRules, + s = e("./behaviour/cstyle").CstyleBehaviour, + o = e("../unicode"), + u = e("../lib/lang"), + a = e("../token_iterator").TokenIterator, + f = e("../range").Range, + l = function() { + this.HighlightRules = i + }; + (function() { + this.$defaultBehaviour = new s, this.tokenRe = new RegExp("^[" + o.packages.L + o.packages.Mn + o.packages.Mc + o.packages.Nd + o.packages.Pc + "\\$_]+", "g"), this.nonTokenRe = new RegExp("^(?:[^" + o.packages.L + o.packages.Mn + o.packages.Mc + o.packages.Nd + o.packages.Pc + "\\$_]|\\s])+", "g"), this.getTokenizer = function() { + return this.$tokenizer || (this.$highlightRules = this.$highlightRules || new this.HighlightRules(this.$highlightRuleConfig), this.$tokenizer = new r(this.$highlightRules.getRules())), this.$tokenizer + }, this.lineCommentStart = "", this.blockComment = "", this.toggleCommentLines = function(e, t, n, r) { + function w(e) { + for (var t = n; t <= r; t++) e(i.getLine(t), t) + } + var i = t.doc, + s = !0, + o = !0, + a = Infinity, + f = t.getTabSize(), + l = !1; + if (!this.lineCommentStart) { + if (!this.blockComment) return !1; + var c = this.blockComment.start, + h = this.blockComment.end, + p = new RegExp("^(\\s*)(?:" + u.escapeRegExp(c) + ")"), + d = new RegExp("(?:" + u.escapeRegExp(h) + ")\\s*$"), + v = function(e, t) { + if (g(e, t)) return; + if (!s || /\S/.test(e)) i.insertInLine({ + row: t, + column: e.length + }, h), i.insertInLine({ + row: t, + column: a + }, c) + }, + m = function(e, t) { + var n; + (n = e.match(d)) && i.removeInLine(t, e.length - n[0].length, e.length), (n = e.match(p)) && i.removeInLine(t, n[1].length, n[0].length) + }, + g = function(e, n) { + if (p.test(e)) return !0; + var r = t.getTokens(n); + for (var i = 0; i < r.length; i++) + if (r[i].type === "comment") return !0 + } + } else { + if (Array.isArray(this.lineCommentStart)) var p = this.lineCommentStart.map(u.escapeRegExp).join("|"), + c = this.lineCommentStart[0]; + else var p = u.escapeRegExp(this.lineCommentStart), + c = this.lineCommentStart; + p = new RegExp("^(\\s*)(?:" + p + ") ?"), l = t.getUseSoftTabs(); + var m = function(e, t) { + var n = e.match(p); + if (!n) return; + var r = n[1].length, + s = n[0].length; + !b(e, r, s) && n[0][s - 1] == " " && s--, i.removeInLine(t, r, s) + }, + y = c + " ", + v = function(e, t) { + if (!s || /\S/.test(e)) b(e, a, a) ? i.insertInLine({ + row: t, + column: a + }, y) : i.insertInLine({ + row: t, + column: a + }, c) + }, + g = function(e, t) { + return p.test(e) + }, + b = function(e, t, n) { + var r = 0; + while (t-- && e.charAt(t) == " ") r++; + if (r % f != 0) return !1; + var r = 0; + while (e.charAt(n++) == " ") r++; + return f > 2 ? r % f != f - 1 : r % f == 0 + } + } + var E = Infinity; + w(function(e, t) { + var n = e.search(/\S/); + n !== -1 ? (n < a && (a = n), o && !g(e, t) && (o = !1)) : E > e.length && (E = e.length) + }), a == Infinity && (a = E, s = !1, o = !1), l && a % f != 0 && (a = Math.floor(a / f) * f), w(o ? m : v) + }, this.toggleBlockComment = function(e, t, n, r) { + var i = this.blockComment; + if (!i) return; + !i.start && i[0] && (i = i[0]); + var s = new a(t, r.row, r.column), + o = s.getCurrentToken(), + u = t.selection, + l = t.selection.toOrientedRange(), + c, h; + if (o && /comment/.test(o.type)) { + var p, d; + while (o && /comment/.test(o.type)) { + var v = o.value.indexOf(i.start); + if (v != -1) { + var m = s.getCurrentTokenRow(), + g = s.getCurrentTokenColumn() + v; + p = new f(m, g, m, g + i.start.length); + break + } + o = s.stepBackward() + } + var s = new a(t, r.row, r.column), + o = s.getCurrentToken(); + while (o && /comment/.test(o.type)) { + var v = o.value.indexOf(i.end); + if (v != -1) { + var m = s.getCurrentTokenRow(), + g = s.getCurrentTokenColumn() + v; + d = new f(m, g, m, g + i.end.length); + break + } + o = s.stepForward() + } + d && t.remove(d), p && (t.remove(p), c = p.start.row, h = -i.start.length) + } else h = i.start.length, c = n.start.row, t.insert(n.end, i.end), t.insert(n.start, i.start); + l.start.row == c && (l.start.column += h), l.end.row == c && (l.end.column += h), t.selection.fromOrientedRange(l) + }, this.getNextLineIndent = function(e, t, n) { + return this.$getIndent(t) + }, this.checkOutdent = function(e, t, n) { + return !1 + }, this.autoOutdent = function(e, t, n) {}, this.$getIndent = function(e) { + return e.match(/^\s*/)[0] + }, this.createWorker = function(e) { + return null + }, this.createModeDelegates = function(e) { + this.$embeds = [], this.$modes = {}; + for (var t in e) e[t] && (this.$embeds.push(t), this.$modes[t] = new e[t]); + var n = ["toggleBlockComment", "toggleCommentLines", "getNextLineIndent", "checkOutdent", "autoOutdent", "transformAction", "getCompletions"]; + for (var t = 0; t < n.length; t++)(function(e) { + var r = n[t], + i = e[r]; + e[n[t]] = function() { + return this.$delegator(r, arguments, i) + } + })(this) + }, this.$delegator = function(e, t, n) { + var r = t[0]; + typeof r != "string" && (r = r[0]); + for (var i = 0; i < this.$embeds.length; i++) { + if (!this.$modes[this.$embeds[i]]) continue; + var s = r.split(this.$embeds[i]); + if (!s[0] && s[1]) { + t[0] = s[1]; + var o = this.$modes[this.$embeds[i]]; + return o[e].apply(o, t) + } + } + var u = n.apply(this, t); + return n ? u : undefined + }, this.transformAction = function(e, t, n, r, i) { + if (this.$behaviour) { + var s = this.$behaviour.getBehaviours(); + for (var o in s) + if (s[o][t]) { + var u = s[o][t].apply(this, arguments); + if (u) return u + } + } + }, this.getKeywords = function(e) { + if (!this.completionKeywords) { + var t = this.$tokenizer.rules, + n = []; + for (var r in t) { + var i = t[r]; + for (var s = 0, o = i.length; s < o; s++) + if (typeof i[s].token == "string") /keyword|support|storage/.test(i[s].token) && n.push(i[s].regex); + else if (typeof i[s].token == "object") + for (var u = 0, a = i[s].token.length; u < a; u++) + if (/keyword|support|storage/.test(i[s].token[u])) { + var r = i[s].regex.match(/\(.+?\)/g)[u]; + n.push(r.substr(1, r.length - 2)) + } + } + this.completionKeywords = n + } + return e ? n.concat(this.$keywordList || []) : this.$keywordList + }, this.$createKeywordList = function() { + return this.$highlightRules || this.getTokenizer(), this.$keywordList = this.$highlightRules.$keywordList || [] + }, this.getCompletions = function(e, t, n, r) { + var i = this.$keywordList || this.$createKeywordList(); + return i.map(function(e) { + return { + name: e, + value: e, + score: 0, + meta: "keyword" + } + }) + }, this.$id = "ace/mode/text" + }).call(l.prototype), t.Mode = l +}), define("ace/apply_delta", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + + function r(e, t) { + throw console.log("Invalid Delta:", e), "Invalid Delta: " + t + } + + function i(e, t) { + return t.row >= 0 && t.row < e.length && t.column >= 0 && t.column <= e[t.row].length + } + + function s(e, t) { + t.action != "insert" && t.action != "remove" && r(t, "delta.action must be 'insert' or 'remove'"), t.lines instanceof Array || r(t, "delta.lines must be an Array"), (!t.start || !t.end) && r(t, "delta.start/end must be an present"); + var n = t.start; + i(e, t.start) || r(t, "delta.start must be contained in document"); + var s = t.end; + t.action == "remove" && !i(e, s) && r(t, "delta.end must contained in document for 'remove' actions"); + var o = s.row - n.row, + u = s.column - (o == 0 ? n.column : 0); + (o != t.lines.length - 1 || t.lines[o].length != u) && r(t, "delta.range must match delta lines") + } + t.applyDelta = function(e, t, n) { + var r = t.start.row, + i = t.start.column, + s = e[r] || ""; + switch (t.action) { + case "insert": + var o = t.lines; + if (o.length === 1) e[r] = s.substring(0, i) + t.lines[0] + s.substring(i); + else { + var u = [r, 1].concat(t.lines); + e.splice.apply(e, u), e[r] = s.substring(0, i) + e[r], e[r + t.lines.length - 1] += s.substring(i) + } + break; + case "remove": + var a = t.end.column, + f = t.end.row; + r === f ? e[r] = s.substring(0, i) + s.substring(a) : e.splice(r, f - r + 1, s.substring(0, i) + e[f].substring(a)) + } + } +}), define("ace/anchor", ["require", "exports", "module", "ace/lib/oop", "ace/lib/event_emitter"], function(e, t, n) { + "use strict"; + var r = e("./lib/oop"), + i = e("./lib/event_emitter").EventEmitter, + s = t.Anchor = function(e, t, n) { + this.$onChange = this.onChange.bind(this), this.attach(e), typeof n == "undefined" ? this.setPosition(t.row, t.column) : this.setPosition(t, n) + }; + (function() { + function e(e, t, n) { + var r = n ? e.column <= t.column : e.column < t.column; + return e.row < t.row || e.row == t.row && r + } + + function t(t, n, r) { + var i = t.action == "insert", + s = (i ? 1 : -1) * (t.end.row - t.start.row), + o = (i ? 1 : -1) * (t.end.column - t.start.column), + u = t.start, + a = i ? u : t.end; + return e(n, u, r) ? { + row: n.row, + column: n.column + } : e(a, n, !r) ? { + row: n.row + s, + column: n.column + (n.row == a.row ? o : 0) + } : { + row: u.row, + column: u.column + } + } + r.implement(this, i), this.getPosition = function() { + return this.$clipPositionToDocument(this.row, this.column) + }, this.getDocument = function() { + return this.document + }, this.$insertRight = !1, this.onChange = function(e) { + if (e.start.row == e.end.row && e.start.row != this.row) return; + if (e.start.row > this.row) return; + var n = t(e, { + row: this.row, + column: this.column + }, this.$insertRight); + this.setPosition(n.row, n.column, !0) + }, this.setPosition = function(e, t, n) { + var r; + n ? r = { + row: e, + column: t + } : r = this.$clipPositionToDocument(e, t); + if (this.row == r.row && this.column == r.column) return; + var i = { + row: this.row, + column: this.column + }; + this.row = r.row, this.column = r.column, this._signal("change", { + old: i, + value: r + }) + }, this.detach = function() { + this.document.removeEventListener("change", this.$onChange) + }, this.attach = function(e) { + this.document = e || this.document, this.document.on("change", this.$onChange) + }, this.$clipPositionToDocument = function(e, t) { + var n = {}; + return e >= this.document.getLength() ? (n.row = Math.max(0, this.document.getLength() - 1), n.column = this.document.getLine(n.row).length) : e < 0 ? (n.row = 0, n.column = 0) : (n.row = e, n.column = Math.min(this.document.getLine(n.row).length, Math.max(0, t))), t < 0 && (n.column = 0), n + } + }).call(s.prototype) +}), define("ace/document", ["require", "exports", "module", "ace/lib/oop", "ace/apply_delta", "ace/lib/event_emitter", "ace/range", "ace/anchor"], function(e, t, n) { + "use strict"; + var r = e("./lib/oop"), + i = e("./apply_delta").applyDelta, + s = e("./lib/event_emitter").EventEmitter, + o = e("./range").Range, + u = e("./anchor").Anchor, + a = function(e) { + this.$lines = [""], e.length === 0 ? this.$lines = [""] : Array.isArray(e) ? this.insertMergedLines({ + row: 0, + column: 0 + }, e) : this.insert({ + row: 0, + column: 0 + }, e) + }; + (function() { + r.implement(this, s), this.setValue = function(e) { + var t = this.getLength() - 1; + this.remove(new o(0, 0, t, this.getLine(t).length)), this.insert({ + row: 0, + column: 0 + }, e) + }, this.getValue = function() { + return this.getAllLines().join(this.getNewLineCharacter()) + }, this.createAnchor = function(e, t) { + return new u(this, e, t) + }, "aaa".split(/a/).length === 0 ? this.$split = function(e) { + return e.replace(/\r\n|\r/g, "\n").split("\n") + } : this.$split = function(e) { + return e.split(/\r\n|\r|\n/) + }, this.$detectNewLine = function(e) { + var t = e.match(/^.*?(\r\n|\r|\n)/m); + this.$autoNewLine = t ? t[1] : "\n", this._signal("changeNewLineMode") + }, this.getNewLineCharacter = function() { + switch (this.$newLineMode) { + case "windows": + return "\r\n"; + case "unix": + return "\n"; + default: + return this.$autoNewLine || "\n" + } + }, this.$autoNewLine = "", this.$newLineMode = "auto", this.setNewLineMode = function(e) { + if (this.$newLineMode === e) return; + this.$newLineMode = e, this._signal("changeNewLineMode") + }, this.getNewLineMode = function() { + return this.$newLineMode + }, this.isNewLine = function(e) { + return e == "\r\n" || e == "\r" || e == "\n" + }, this.getLine = function(e) { + return this.$lines[e] || "" + }, this.getLines = function(e, t) { + return this.$lines.slice(e, t + 1) + }, this.getAllLines = function() { + return this.getLines(0, this.getLength()) + }, this.getLength = function() { + return this.$lines.length + }, this.getTextRange = function(e) { + return this.getLinesForRange(e).join(this.getNewLineCharacter()) + }, this.getLinesForRange = function(e) { + var t; + if (e.start.row === e.end.row) t = [this.getLine(e.start.row).substring(e.start.column, e.end.column)]; + else { + t = this.getLines(e.start.row, e.end.row), t[0] = (t[0] || "").substring(e.start.column); + var n = t.length - 1; + e.end.row - e.start.row == n && (t[n] = t[n].substring(0, e.end.column)) + } + return t + }, this.insertLines = function(e, t) { + return console.warn("Use of document.insertLines is deprecated. Use the insertFullLines method instead."), this.insertFullLines(e, t) + }, this.removeLines = function(e, t) { + return console.warn("Use of document.removeLines is deprecated. Use the removeFullLines method instead."), this.removeFullLines(e, t) + }, this.insertNewLine = function(e) { + return console.warn("Use of document.insertNewLine is deprecated. Use insertMergedLines(position, ['', '']) instead."), this.insertMergedLines(e, ["", ""]) + }, this.insert = function(e, t) { + return this.getLength() <= 1 && this.$detectNewLine(t), this.insertMergedLines(e, this.$split(t)) + }, this.insertInLine = function(e, t) { + var n = this.clippedPos(e.row, e.column), + r = this.pos(e.row, e.column + t.length); + return this.applyDelta({ + start: n, + end: r, + action: "insert", + lines: [t] + }, !0), this.clonePos(r) + }, this.clippedPos = function(e, t) { + var n = this.getLength(); + e === undefined ? e = n : e < 0 ? e = 0 : e >= n && (e = n - 1, t = undefined); + var r = this.getLine(e); + return t == undefined && (t = r.length), t = Math.min(Math.max(t, 0), r.length), { + row: e, + column: t + } + }, this.clonePos = function(e) { + return { + row: e.row, + column: e.column + } + }, this.pos = function(e, t) { + return { + row: e, + column: t + } + }, this.$clipPosition = function(e) { + var t = this.getLength(); + return e.row >= t ? (e.row = Math.max(0, t - 1), e.column = this.getLine(t - 1).length) : (e.row = Math.max(0, e.row), e.column = Math.min(Math.max(e.column, 0), this.getLine(e.row).length)), e + }, this.insertFullLines = function(e, t) { + e = Math.min(Math.max(e, 0), this.getLength()); + var n = 0; + e < this.getLength() ? (t = t.concat([""]), n = 0) : (t = [""].concat(t), e--, n = this.$lines[e].length), this.insertMergedLines({ + row: e, + column: n + }, t) + }, this.insertMergedLines = function(e, t) { + var n = this.clippedPos(e.row, e.column), + r = { + row: n.row + t.length - 1, + column: (t.length == 1 ? n.column : 0) + t[t.length - 1].length + }; + return this.applyDelta({ + start: n, + end: r, + action: "insert", + lines: t + }), this.clonePos(r) + }, this.remove = function(e) { + var t = this.clippedPos(e.start.row, e.start.column), + n = this.clippedPos(e.end.row, e.end.column); + return this.applyDelta({ + start: t, + end: n, + action: "remove", + lines: this.getLinesForRange({ + start: t, + end: n + }) + }), this.clonePos(t) + }, this.removeInLine = function(e, t, n) { + var r = this.clippedPos(e, t), + i = this.clippedPos(e, n); + return this.applyDelta({ + start: r, + end: i, + action: "remove", + lines: this.getLinesForRange({ + start: r, + end: i + }) + }, !0), this.clonePos(r) + }, this.removeFullLines = function(e, t) { + e = Math.min(Math.max(0, e), this.getLength() - 1), t = Math.min(Math.max(0, t), this.getLength() - 1); + var n = t == this.getLength() - 1 && e > 0, + r = t < this.getLength() - 1, + i = n ? e - 1 : e, + s = n ? this.getLine(i).length : 0, + u = r ? t + 1 : t, + a = r ? 0 : this.getLine(u).length, + f = new o(i, s, u, a), + l = this.$lines.slice(e, t + 1); + return this.applyDelta({ + start: f.start, + end: f.end, + action: "remove", + lines: this.getLinesForRange(f) + }), l + }, this.removeNewLine = function(e) { + e < this.getLength() - 1 && e >= 0 && this.applyDelta({ + start: this.pos(e, this.getLine(e).length), + end: this.pos(e + 1, 0), + action: "remove", + lines: ["", ""] + }) + }, this.replace = function(e, t) { + e instanceof o || (e = o.fromPoints(e.start, e.end)); + if (t.length === 0 && e.isEmpty()) return e.start; + if (t == this.getTextRange(e)) return e.end; + this.remove(e); + var n; + return t ? n = this.insert(e.start, t) : n = e.start, n + }, this.applyDeltas = function(e) { + for (var t = 0; t < e.length; t++) this.applyDelta(e[t]) + }, this.revertDeltas = function(e) { + for (var t = e.length - 1; t >= 0; t--) this.revertDelta(e[t]) + }, this.applyDelta = function(e, t) { + var n = e.action == "insert"; + if (n ? e.lines.length <= 1 && !e.lines[0] : !o.comparePoints(e.start, e.end)) return; + n && e.lines.length > 2e4 && this.$splitAndapplyLargeDelta(e, 2e4), i(this.$lines, e, t), this._signal("change", e) + }, this.$splitAndapplyLargeDelta = function(e, t) { + var n = e.lines, + r = n.length, + i = e.start.row, + s = e.start.column, + o = 0, + u = 0; + do { + o = u, u += t - 1; + var a = n.slice(o, u); + if (u > r) { + e.lines = a, e.start.row = i + o, e.start.column = s; + break + } + a.push(""), this.applyDelta({ + start: this.pos(i + o, s), + end: this.pos(i + u, s = 0), + action: e.action, + lines: a + }, !0) + } while (!0) + }, this.revertDelta = function(e) { + this.applyDelta({ + start: this.clonePos(e.start), + end: this.clonePos(e.end), + action: e.action == "insert" ? "remove" : "insert", + lines: e.lines.slice() + }) + }, this.indexToPosition = function(e, t) { + var n = this.$lines || this.getAllLines(), + r = this.getNewLineCharacter().length; + for (var i = t || 0, s = n.length; i < s; i++) { + e -= n[i].length + r; + if (e < 0) return { + row: i, + column: e + n[i].length + r + } + } + return { + row: s - 1, + column: n[s - 1].length + } + }, this.positionToIndex = function(e, t) { + var n = this.$lines || this.getAllLines(), + r = this.getNewLineCharacter().length, + i = 0, + s = Math.min(e.row, n.length); + for (var o = t || 0; o < s; ++o) i += n[o].length + r; + return i + e.column + } + }).call(a.prototype), t.Document = a +}), define("ace/background_tokenizer", ["require", "exports", "module", "ace/lib/oop", "ace/lib/event_emitter"], function(e, t, n) { + "use strict"; + var r = e("./lib/oop"), + i = e("./lib/event_emitter").EventEmitter, + s = function(e, t) { + this.running = !1, this.lines = [], this.states = [], this.currentLine = 0, this.tokenizer = e; + var n = this; + this.$worker = function() { + if (!n.running) return; + var e = new Date, + t = n.currentLine, + r = -1, + i = n.doc, + s = t; + while (n.lines[t]) t++; + var o = i.getLength(), + u = 0; + n.running = !1; + while (t < o) { + n.$tokenizeRow(t), r = t; + do t++; while (n.lines[t]); + u++; + if (u % 5 === 0 && new Date - e > 20) { + n.running = setTimeout(n.$worker, 20); + break + } + } + n.currentLine = t, r == -1 && (r = t), s <= r && n.fireUpdateEvent(s, r) + } + }; + (function() { + r.implement(this, i), this.setTokenizer = function(e) { + this.tokenizer = e, this.lines = [], this.states = [], this.start(0) + }, this.setDocument = function(e) { + this.doc = e, this.lines = [], this.states = [], this.stop() + }, this.fireUpdateEvent = function(e, t) { + var n = { + first: e, + last: t + }; + this._signal("update", { + data: n + }) + }, this.start = function(e) { + this.currentLine = Math.min(e || 0, this.currentLine, this.doc.getLength()), this.lines.splice(this.currentLine, this.lines.length), this.states.splice(this.currentLine, this.states.length), this.stop(), this.running = setTimeout(this.$worker, 700) + }, this.scheduleStart = function() { + this.running || (this.running = setTimeout(this.$worker, 700)) + }, this.$updateOnChange = function(e) { + var t = e.start.row, + n = e.end.row - t; + if (n === 0) this.lines[t] = null; + else if (e.action == "remove") this.lines.splice(t, n + 1, null), this.states.splice(t, n + 1, null); + else { + var r = Array(n + 1); + r.unshift(t, 1), this.lines.splice.apply(this.lines, r), this.states.splice.apply(this.states, r) + } + this.currentLine = Math.min(t, this.currentLine, this.doc.getLength()), this.stop() + }, this.stop = function() { + this.running && clearTimeout(this.running), this.running = !1 + }, this.getTokens = function(e) { + return this.lines[e] || this.$tokenizeRow(e) + }, this.getState = function(e) { + return this.currentLine == e && this.$tokenizeRow(e), this.states[e] || "start" + }, this.$tokenizeRow = function(e) { + var t = this.doc.getLine(e), + n = this.states[e - 1], + r = this.tokenizer.getLineTokens(t, n, e); + return this.states[e] + "" != r.state + "" ? (this.states[e] = r.state, this.lines[e + 1] = null, this.currentLine > e + 1 && (this.currentLine = e + 1)) : this.currentLine == e && (this.currentLine = e + 1), this.lines[e] = r.tokens + } + }).call(s.prototype), t.BackgroundTokenizer = s +}), define("ace/search_highlight", ["require", "exports", "module", "ace/lib/lang", "ace/lib/oop", "ace/range"], function(e, t, n) { + "use strict"; + var r = e("./lib/lang"), + i = e("./lib/oop"), + s = e("./range").Range, + o = function(e, t, n) { + this.setRegexp(e), this.clazz = t, this.type = n || "text" + }; + (function() { + this.MAX_RANGES = 500, this.setRegexp = function(e) { + if (this.regExp + "" == e + "") return; + this.regExp = e, this.cache = [] + }, this.update = function(e, t, n, i) { + if (!this.regExp) return; + var o = i.firstRow, + u = i.lastRow; + for (var a = o; a <= u; a++) { + var f = this.cache[a]; + f == null && (f = r.getMatchOffsets(n.getLine(a), this.regExp), f.length > this.MAX_RANGES && (f = f.slice(0, this.MAX_RANGES)), f = f.map(function(e) { + return new s(a, e.offset, a, e.offset + e.length) + }), this.cache[a] = f.length ? f : ""); + for (var l = f.length; l--;) t.drawSingleLineMarker(e, f[l].toScreenRange(n), this.clazz, i) + } + } + }).call(o.prototype), t.SearchHighlight = o +}), define("ace/edit_session/fold_line", ["require", "exports", "module", "ace/range"], function(e, t, n) { + "use strict"; + + function i(e, t) { + this.foldData = e, Array.isArray(t) ? this.folds = t : t = this.folds = [t]; + var n = t[t.length - 1]; + this.range = new r(t[0].start.row, t[0].start.column, n.end.row, n.end.column), this.start = this.range.start, this.end = this.range.end, this.folds.forEach(function(e) { + e.setFoldLine(this) + }, this) + } + var r = e("../range").Range; + (function() { + this.shiftRow = function(e) { + this.start.row += e, this.end.row += e, this.folds.forEach(function(t) { + t.start.row += e, t.end.row += e + }) + }, this.addFold = function(e) { + if (e.sameRow) { + if (e.start.row < this.startRow || e.endRow > this.endRow) throw new Error("Can't add a fold to this FoldLine as it has no connection"); + this.folds.push(e), this.folds.sort(function(e, t) { + return -e.range.compareEnd(t.start.row, t.start.column) + }), this.range.compareEnd(e.start.row, e.start.column) > 0 ? (this.end.row = e.end.row, this.end.column = e.end.column) : this.range.compareStart(e.end.row, e.end.column) < 0 && (this.start.row = e.start.row, this.start.column = e.start.column) + } else if (e.start.row == this.end.row) this.folds.push(e), this.end.row = e.end.row, this.end.column = e.end.column; + else { + if (e.end.row != this.start.row) throw new Error("Trying to add fold to FoldRow that doesn't have a matching row"); + this.folds.unshift(e), this.start.row = e.start.row, this.start.column = e.start.column + } + e.foldLine = this + }, this.containsRow = function(e) { + return e >= this.start.row && e <= this.end.row + }, this.walk = function(e, t, n) { + var r = 0, + i = this.folds, + s, o, u, a = !0; + t == null && (t = this.end.row, n = this.end.column); + for (var f = 0; f < i.length; f++) { + s = i[f], o = s.range.compareStart(t, n); + if (o == -1) { + e(null, t, n, r, a); + return + } + u = e(null, s.start.row, s.start.column, r, a), u = !u && e(s.placeholder, s.start.row, s.start.column, r); + if (u || o === 0) return; + a = !s.sameRow, r = s.end.column + } + e(null, t, n, r, a) + }, this.getNextFoldTo = function(e, t) { + var n, r; + for (var i = 0; i < this.folds.length; i++) { + n = this.folds[i], r = n.range.compareEnd(e, t); + if (r == -1) return { + fold: n, + kind: "after" + }; + if (r === 0) return { + fold: n, + kind: "inside" + } + } + return null + }, this.addRemoveChars = function(e, t, n) { + var r = this.getNextFoldTo(e, t), + i, s; + if (r) { + i = r.fold; + if (r.kind == "inside" && i.start.column != t && i.start.row != e) window.console && window.console.log(e, t, i); + else if (i.start.row == e) { + s = this.folds; + var o = s.indexOf(i); + o === 0 && (this.start.column += n); + for (o; o < s.length; o++) { + i = s[o], i.start.column += n; + if (!i.sameRow) return; + i.end.column += n + } + this.end.column += n + } + } + }, this.split = function(e, t) { + var n = this.getNextFoldTo(e, t); + if (!n || n.kind == "inside") return null; + var r = n.fold, + s = this.folds, + o = this.foldData, + u = s.indexOf(r), + a = s[u - 1]; + this.end.row = a.end.row, this.end.column = a.end.column, s = s.splice(u, s.length - u); + var f = new i(o, s); + return o.splice(o.indexOf(this) + 1, 0, f), f + }, this.merge = function(e) { + var t = e.folds; + for (var n = 0; n < t.length; n++) this.addFold(t[n]); + var r = this.foldData; + r.splice(r.indexOf(e), 1) + }, this.toString = function() { + var e = [this.range.toString() + ": ["]; + return this.folds.forEach(function(t) { + e.push(" " + t.toString()) + }), e.push("]"), e.join("\n") + }, this.idxToPosition = function(e) { + var t = 0; + for (var n = 0; n < this.folds.length; n++) { + var r = this.folds[n]; + e -= r.start.column - t; + if (e < 0) return { + row: r.start.row, + column: r.start.column + e + }; + e -= r.placeholder.length; + if (e < 0) return r.start; + t = r.end.column + } + return { + row: this.end.row, + column: this.end.column + e + } + } + }).call(i.prototype), t.FoldLine = i +}), define("ace/range_list", ["require", "exports", "module", "ace/range"], function(e, t, n) { + "use strict"; + var r = e("./range").Range, + i = r.comparePoints, + s = function() { + this.ranges = [] + }; + (function() { + this.comparePoints = i, this.pointIndex = function(e, t, n) { + var r = this.ranges; + for (var s = n || 0; s < r.length; s++) { + var o = r[s], + u = i(e, o.end); + if (u > 0) continue; + var a = i(e, o.start); + return u === 0 ? t && a !== 0 ? -s - 2 : s : a > 0 || a === 0 && !t ? s : -s - 1 + } + return -s - 1 + }, this.add = function(e) { + var t = !e.isEmpty(), + n = this.pointIndex(e.start, t); + n < 0 && (n = -n - 1); + var r = this.pointIndex(e.end, t, n); + return r < 0 ? r = -r - 1 : r++, this.ranges.splice(n, r - n, e) + }, this.addList = function(e) { + var t = []; + for (var n = e.length; n--;) t.push.apply(t, this.add(e[n])); + return t + }, this.substractPoint = function(e) { + var t = this.pointIndex(e); + if (t >= 0) return this.ranges.splice(t, 1) + }, this.merge = function() { + var e = [], + t = this.ranges; + t = t.sort(function(e, t) { + return i(e.start, t.start) + }); + var n = t[0], + r; + for (var s = 1; s < t.length; s++) { + r = n, n = t[s]; + var o = i(r.end, n.start); + if (o < 0) continue; + if (o == 0 && !r.isEmpty() && !n.isEmpty()) continue; + i(r.end, n.end) < 0 && (r.end.row = n.end.row, r.end.column = n.end.column), t.splice(s, 1), e.push(n), n = r, s-- + } + return this.ranges = t, e + }, this.contains = function(e, t) { + return this.pointIndex({ + row: e, + column: t + }) >= 0 + }, this.containsPoint = function(e) { + return this.pointIndex(e) >= 0 + }, this.rangeAtPoint = function(e) { + var t = this.pointIndex(e); + if (t >= 0) return this.ranges[t] + }, this.clipRows = function(e, t) { + var n = this.ranges; + if (n[0].start.row > t || n[n.length - 1].start.row < e) return []; + var r = this.pointIndex({ + row: e, + column: 0 + }); + r < 0 && (r = -r - 1); + var i = this.pointIndex({ + row: t, + column: 0 + }, r); + i < 0 && (i = -i - 1); + var s = []; + for (var o = r; o < i; o++) s.push(n[o]); + return s + }, this.removeAll = function() { + return this.ranges.splice(0, this.ranges.length) + }, this.attach = function(e) { + this.session && this.detach(), this.session = e, this.onChange = this.$onChange.bind(this), this.session.on("change", this.onChange) + }, this.detach = function() { + if (!this.session) return; + this.session.removeListener("change", this.onChange), this.session = null + }, this.$onChange = function(e) { + if (e.action == "insert") var t = e.start, + n = e.end; + else var n = e.start, + t = e.end; + var r = t.row, + i = n.row, + s = i - r, + o = -t.column + n.column, + u = this.ranges; + for (var a = 0, f = u.length; a < f; a++) { + var l = u[a]; + if (l.end.row < r) continue; + if (l.start.row > r) break; + l.start.row == r && l.start.column >= t.column && (l.start.column != t.column || !this.$insertRight) && (l.start.column += o, l.start.row += s); + if (l.end.row == r && l.end.column >= t.column) { + if (l.end.column == t.column && this.$insertRight) continue; + l.end.column == t.column && o > 0 && a < f - 1 && l.end.column > l.start.column && l.end.column == u[a + 1].start.column && (l.end.column -= o), l.end.column += o, l.end.row += s + } + } + if (s != 0 && a < f) + for (; a < f; a++) { + var l = u[a]; + l.start.row += s, l.end.row += s + } + } + }).call(s.prototype), t.RangeList = s +}), define("ace/edit_session/fold", ["require", "exports", "module", "ace/range", "ace/range_list", "ace/lib/oop"], function(e, t, n) { + "use strict"; + + function u(e, t) { + e.row -= t.row, e.row == 0 && (e.column -= t.column) + } + + function a(e, t) { + u(e.start, t), u(e.end, t) + } + + function f(e, t) { + e.row == 0 && (e.column += t.column), e.row += t.row + } + + function l(e, t) { + f(e.start, t), f(e.end, t) + } + var r = e("../range").Range, + i = e("../range_list").RangeList, + s = e("../lib/oop"), + o = t.Fold = function(e, t) { + this.foldLine = null, this.placeholder = t, this.range = e, this.start = e.start, this.end = e.end, this.sameRow = e.start.row == e.end.row, this.subFolds = this.ranges = [] + }; + s.inherits(o, i), + function() { + this.toString = function() { + return '"' + this.placeholder + '" ' + this.range.toString() + }, this.setFoldLine = function(e) { + this.foldLine = e, this.subFolds.forEach(function(t) { + t.setFoldLine(e) + }) + }, this.clone = function() { + var e = this.range.clone(), + t = new o(e, this.placeholder); + return this.subFolds.forEach(function(e) { + t.subFolds.push(e.clone()) + }), t.collapseChildren = this.collapseChildren, t + }, this.addSubFold = function(e) { + if (this.range.isEqual(e)) return; + if (!this.range.containsRange(e)) throw new Error("A fold can't intersect already existing fold" + e.range + this.range); + a(e, this.start); + var t = e.start.row, + n = e.start.column; + for (var r = 0, i = -1; r < this.subFolds.length; r++) { + i = this.subFolds[r].range.compare(t, n); + if (i != 1) break + } + var s = this.subFolds[r]; + if (i == 0) return s.addSubFold(e); + var t = e.range.end.row, + n = e.range.end.column; + for (var o = r, i = -1; o < this.subFolds.length; o++) { + i = this.subFolds[o].range.compare(t, n); + if (i != 1) break + } + var u = this.subFolds[o]; + if (i == 0) throw new Error("A fold can't intersect already existing fold" + e.range + this.range); + var f = this.subFolds.splice(r, o - r, e); + return e.setFoldLine(this.foldLine), e + }, this.restoreRange = function(e) { + return l(e, this.start) + } + }.call(o.prototype) +}), define("ace/edit_session/folding", ["require", "exports", "module", "ace/range", "ace/edit_session/fold_line", "ace/edit_session/fold", "ace/token_iterator"], function(e, t, n) { + "use strict"; + + function u() { + this.getFoldAt = function(e, t, n) { + var r = this.getFoldLine(e); + if (!r) return null; + var i = r.folds; + for (var s = 0; s < i.length; s++) { + var o = i[s]; + if (o.range.contains(e, t)) { + if (n == 1 && o.range.isEnd(e, t)) continue; + if (n == -1 && o.range.isStart(e, t)) continue; + return o + } + } + }, this.getFoldsInRange = function(e) { + var t = e.start, + n = e.end, + r = this.$foldData, + i = []; + t.column += 1, n.column -= 1; + for (var s = 0; s < r.length; s++) { + var o = r[s].range.compareRange(e); + if (o == 2) continue; + if (o == -2) break; + var u = r[s].folds; + for (var a = 0; a < u.length; a++) { + var f = u[a]; + o = f.range.compareRange(e); + if (o == -2) break; + if (o == 2) continue; + if (o == 42) break; + i.push(f) + } + } + return t.column -= 1, n.column += 1, i + }, this.getFoldsInRangeList = function(e) { + if (Array.isArray(e)) { + var t = []; + e.forEach(function(e) { + t = t.concat(this.getFoldsInRange(e)) + }, this) + } else var t = this.getFoldsInRange(e); + return t + }, this.getAllFolds = function() { + var e = [], + t = this.$foldData; + for (var n = 0; n < t.length; n++) + for (var r = 0; r < t[n].folds.length; r++) e.push(t[n].folds[r]); + return e + }, this.getFoldStringAt = function(e, t, n, r) { + r = r || this.getFoldLine(e); + if (!r) return null; + var i = { + end: { + column: 0 + } + }, + s, o; + for (var u = 0; u < r.folds.length; u++) { + o = r.folds[u]; + var a = o.range.compareEnd(e, t); + if (a == -1) { + s = this.getLine(o.start.row).substring(i.end.column, o.start.column); + break + } + if (a === 0) return null; + i = o + } + return s || (s = this.getLine(o.start.row).substring(i.end.column)), n == -1 ? s.substring(0, t - i.end.column) : n == 1 ? s.substring(t - i.end.column) : s + }, this.getFoldLine = function(e, t) { + var n = this.$foldData, + r = 0; + t && (r = n.indexOf(t)), r == -1 && (r = 0); + for (r; r < n.length; r++) { + var i = n[r]; + if (i.start.row <= e && i.end.row >= e) return i; + if (i.end.row > e) return null + } + return null + }, this.getNextFoldLine = function(e, t) { + var n = this.$foldData, + r = 0; + t && (r = n.indexOf(t)), r == -1 && (r = 0); + for (r; r < n.length; r++) { + var i = n[r]; + if (i.end.row >= e) return i + } + return null + }, this.getFoldedRowCount = function(e, t) { + var n = this.$foldData, + r = t - e + 1; + for (var i = 0; i < n.length; i++) { + var s = n[i], + o = s.end.row, + u = s.start.row; + if (o >= t) { + u < t && (u >= e ? r -= t - u : r = 0); + break + } + o >= e && (u >= e ? r -= o - u : r -= o - e + 1) + } + return r + }, this.$addFoldLine = function(e) { + return this.$foldData.push(e), this.$foldData.sort(function(e, t) { + return e.start.row - t.start.row + }), e + }, this.addFold = function(e, t) { + var n = this.$foldData, + r = !1, + o; + e instanceof s ? o = e : (o = new s(t, e), o.collapseChildren = t.collapseChildren), this.$clipRangeToDocument(o.range); + var u = o.start.row, + a = o.start.column, + f = o.end.row, + l = o.end.column; + if (u < f || u == f && a <= l - 2) { + var c = this.getFoldAt(u, a, 1), + h = this.getFoldAt(f, l, -1); + if (c && h == c) return c.addSubFold(o); + c && !c.range.isStart(u, a) && this.removeFold(c), h && !h.range.isEnd(f, l) && this.removeFold(h); + var p = this.getFoldsInRange(o.range); + p.length > 0 && (this.removeFolds(p), p.forEach(function(e) { + o.addSubFold(e) + })); + for (var d = 0; d < n.length; d++) { + var v = n[d]; + if (f == v.start.row) { + v.addFold(o), r = !0; + break + } + if (u == v.end.row) { + v.addFold(o), r = !0; + if (!o.sameRow) { + var m = n[d + 1]; + if (m && m.start.row == f) { + v.merge(m); + break + } + } + break + } + if (f <= v.start.row) break + } + return r || (v = this.$addFoldLine(new i(this.$foldData, o))), this.$useWrapMode ? this.$updateWrapData(v.start.row, v.start.row) : this.$updateRowLengthCache(v.start.row, v.start.row), this.$modified = !0, this._signal("changeFold", { + data: o, + action: "add" + }), o + } + throw new Error("The range has to be at least 2 characters width") + }, this.addFolds = function(e) { + e.forEach(function(e) { + this.addFold(e) + }, this) + }, this.removeFold = function(e) { + var t = e.foldLine, + n = t.start.row, + r = t.end.row, + i = this.$foldData, + s = t.folds; + if (s.length == 1) i.splice(i.indexOf(t), 1); + else if (t.range.isEnd(e.end.row, e.end.column)) s.pop(), t.end.row = s[s.length - 1].end.row, t.end.column = s[s.length - 1].end.column; + else if (t.range.isStart(e.start.row, e.start.column)) s.shift(), t.start.row = s[0].start.row, t.start.column = s[0].start.column; + else if (e.sameRow) s.splice(s.indexOf(e), 1); + else { + var o = t.split(e.start.row, e.start.column); + s = o.folds, s.shift(), o.start.row = s[0].start.row, o.start.column = s[0].start.column + } + this.$updating || (this.$useWrapMode ? this.$updateWrapData(n, r) : this.$updateRowLengthCache(n, r)), this.$modified = !0, this._signal("changeFold", { + data: e, + action: "remove" + }) + }, this.removeFolds = function(e) { + var t = []; + for (var n = 0; n < e.length; n++) t.push(e[n]); + t.forEach(function(e) { + this.removeFold(e) + }, this), this.$modified = !0 + }, this.expandFold = function(e) { + this.removeFold(e), e.subFolds.forEach(function(t) { + e.restoreRange(t), this.addFold(t) + }, this), e.collapseChildren > 0 && this.foldAll(e.start.row + 1, e.end.row, e.collapseChildren - 1), e.subFolds = [] + }, this.expandFolds = function(e) { + e.forEach(function(e) { + this.expandFold(e) + }, this) + }, this.unfold = function(e, t) { + var n, i; + e == null ? (n = new r(0, 0, this.getLength(), 0), t = !0) : typeof e == "number" ? n = new r(e, 0, e, this.getLine(e).length) : "row" in e ? n = r.fromPoints(e, e) : n = e, i = this.getFoldsInRangeList(n); + if (t) this.removeFolds(i); + else { + var s = i; + while (s.length) this.expandFolds(s), s = this.getFoldsInRangeList(n) + } + if (i.length) return i + }, this.isRowFolded = function(e, t) { + return !!this.getFoldLine(e, t) + }, this.getRowFoldEnd = function(e, t) { + var n = this.getFoldLine(e, t); + return n ? n.end.row : e + }, this.getRowFoldStart = function(e, t) { + var n = this.getFoldLine(e, t); + return n ? n.start.row : e + }, this.getFoldDisplayLine = function(e, t, n, r, i) { + r == null && (r = e.start.row), i == null && (i = 0), t == null && (t = e.end.row), n == null && (n = this.getLine(t).length); + var s = this.doc, + o = ""; + return e.walk(function(e, t, n, u) { + if (t < r) return; + if (t == r) { + if (n < i) return; + u = Math.max(i, u) + } + e != null ? o += e : o += s.getLine(t).substring(u, n) + }, t, n), o + }, this.getDisplayLine = function(e, t, n, r) { + var i = this.getFoldLine(e); + if (!i) { + var s; + return s = this.doc.getLine(e), s.substring(r || 0, t || s.length) + } + return this.getFoldDisplayLine(i, e, t, n, r) + }, this.$cloneFoldData = function() { + var e = []; + return e = this.$foldData.map(function(t) { + var n = t.folds.map(function(e) { + return e.clone() + }); + return new i(e, n) + }), e + }, this.toggleFold = function(e) { + var t = this.selection, + n = t.getRange(), + r, i; + if (n.isEmpty()) { + var s = n.start; + r = this.getFoldAt(s.row, s.column); + if (r) { + this.expandFold(r); + return + }(i = this.findMatchingBracket(s)) ? n.comparePoint(i) == 1 ? n.end = i : (n.start = i, n.start.column++, n.end.column--): (i = this.findMatchingBracket({ + row: s.row, + column: s.column + 1 + })) ? (n.comparePoint(i) == 1 ? n.end = i : n.start = i, n.start.column++) : n = this.getCommentFoldRange(s.row, s.column) || n + } else { + var o = this.getFoldsInRange(n); + if (e && o.length) { + this.expandFolds(o); + return + } + o.length == 1 && (r = o[0]) + } + r || (r = this.getFoldAt(n.start.row, n.start.column)); + if (r && r.range.toString() == n.toString()) { + this.expandFold(r); + return + } + var u = "..."; + if (!n.isMultiLine()) { + u = this.getTextRange(n); + if (u.length < 4) return; + u = u.trim().substring(0, 2) + ".." + } + this.addFold(u, n) + }, this.getCommentFoldRange = function(e, t, n) { + var i = new o(this, e, t), + s = i.getCurrentToken(), + u = s.type; + if (s && /^comment|string/.test(u)) { + u = u.match(/comment|string/)[0], u == "comment" && (u += "|doc-start"); + var a = new RegExp(u), + f = new r; + if (n != 1) { + do s = i.stepBackward(); while (s && a.test(s.type)); + i.stepForward() + } + f.start.row = i.getCurrentTokenRow(), f.start.column = i.getCurrentTokenColumn() + 2, i = new o(this, e, t); + if (n != -1) { + var l = -1; + do { + s = i.stepForward(); + if (l == -1) { + var c = this.getState(i.$row); + a.test(c) || (l = i.$row) + } else if (i.$row > l) break + } while (s && a.test(s.type)); + s = i.stepBackward() + } else s = i.getCurrentToken(); + return f.end.row = i.getCurrentTokenRow(), f.end.column = i.getCurrentTokenColumn() + s.value.length - 2, f + } + }, this.foldAll = function(e, t, n) { + n == undefined && (n = 1e5); + var r = this.foldWidgets; + if (!r) return; + t = t || this.getLength(), e = e || 0; + for (var i = e; i < t; i++) { + r[i] == null && (r[i] = this.getFoldWidget(i)); + if (r[i] != "start") continue; + var s = this.getFoldWidgetRange(i); + if (s && s.isMultiLine() && s.end.row <= t && s.start.row >= e) { + i = s.end.row; + try { + var o = this.addFold("...", s); + o && (o.collapseChildren = n) + } catch (u) {} + } + } + }, this.$foldStyles = { + manual: 1, + markbegin: 1, + markbeginend: 1 + }, this.$foldStyle = "markbegin", this.setFoldStyle = function(e) { + if (!this.$foldStyles[e]) throw new Error("invalid fold style: " + e + "[" + Object.keys(this.$foldStyles).join(", ") + "]"); + if (this.$foldStyle == e) return; + this.$foldStyle = e, e == "manual" && this.unfold(); + var t = this.$foldMode; + this.$setFolding(null), this.$setFolding(t) + }, this.$setFolding = function(e) { + if (this.$foldMode == e) return; + this.$foldMode = e, this.off("change", this.$updateFoldWidgets), this.off("tokenizerUpdate", this.$tokenizerUpdateFoldWidgets), this._signal("changeAnnotation"); + if (!e || this.$foldStyle == "manual") { + this.foldWidgets = null; + return + } + this.foldWidgets = [], this.getFoldWidget = e.getFoldWidget.bind(e, this, this.$foldStyle), this.getFoldWidgetRange = e.getFoldWidgetRange.bind(e, this, this.$foldStyle), this.$updateFoldWidgets = this.updateFoldWidgets.bind(this), this.$tokenizerUpdateFoldWidgets = this.tokenizerUpdateFoldWidgets.bind(this), this.on("change", this.$updateFoldWidgets), this.on("tokenizerUpdate", this.$tokenizerUpdateFoldWidgets) + }, this.getParentFoldRangeData = function(e, t) { + var n = this.foldWidgets; + if (!n || t && n[e]) return {}; + var r = e - 1, + i; + while (r >= 0) { + var s = n[r]; + s == null && (s = n[r] = this.getFoldWidget(r)); + if (s == "start") { + var o = this.getFoldWidgetRange(r); + i || (i = o); + if (o && o.end.row >= e) break + } + r-- + } + return { + range: r !== -1 && o, + firstRange: i + } + }, this.onFoldWidgetClick = function(e, t) { + t = t.domEvent; + var n = { + children: t.shiftKey, + all: t.ctrlKey || t.metaKey, + siblings: t.altKey + }, + r = this.$toggleFoldWidget(e, n); + if (!r) { + var i = t.target || t.srcElement; + i && /ace_fold-widget/.test(i.className) && (i.className += " ace_invalid") + } + }, this.$toggleFoldWidget = function(e, t) { + if (!this.getFoldWidget) return; + var n = this.getFoldWidget(e), + r = this.getLine(e), + i = n === "end" ? -1 : 1, + s = this.getFoldAt(e, i === -1 ? 0 : r.length, i); + if (s) return t.children || t.all ? this.removeFold(s) : this.expandFold(s), s; + var o = this.getFoldWidgetRange(e, !0); + if (o && !o.isMultiLine()) { + s = this.getFoldAt(o.start.row, o.start.column, 1); + if (s && o.isEqual(s.range)) return this.removeFold(s), s + } + if (t.siblings) { + var u = this.getParentFoldRangeData(e); + if (u.range) var a = u.range.start.row + 1, + f = u.range.end.row; + this.foldAll(a, f, t.all ? 1e4 : 0) + } else t.children ? (f = o ? o.end.row : this.getLength(), this.foldAll(e + 1, f, t.all ? 1e4 : 0)) : o && (t.all && (o.collapseChildren = 1e4), this.addFold("...", o)); + return o + }, this.toggleFoldWidget = function(e) { + var t = this.selection.getCursor().row; + t = this.getRowFoldStart(t); + var n = this.$toggleFoldWidget(t, {}); + if (n) return; + var r = this.getParentFoldRangeData(t, !0); + n = r.range || r.firstRange; + if (n) { + t = n.start.row; + var i = this.getFoldAt(t, this.getLine(t).length, 1); + i ? this.removeFold(i) : this.addFold("...", n) + } + }, this.updateFoldWidgets = function(e) { + var t = e.start.row, + n = e.end.row - t; + if (n === 0) this.foldWidgets[t] = null; + else if (e.action == "remove") this.foldWidgets.splice(t, n + 1, null); + else { + var r = Array(n + 1); + r.unshift(t, 1), this.foldWidgets.splice.apply(this.foldWidgets, r) + } + }, this.tokenizerUpdateFoldWidgets = function(e) { + var t = e.data; + t.first != t.last && this.foldWidgets.length > t.first && this.foldWidgets.splice(t.first, this.foldWidgets.length) + } + } + var r = e("../range").Range, + i = e("./fold_line").FoldLine, + s = e("./fold").Fold, + o = e("../token_iterator").TokenIterator; + t.Folding = u +}), define("ace/edit_session/bracket_match", ["require", "exports", "module", "ace/token_iterator", "ace/range"], function(e, t, n) { + "use strict"; + + function s() { + this.findMatchingBracket = function(e, t) { + if (e.column == 0) return null; + var n = t || this.getLine(e.row).charAt(e.column - 1); + if (n == "") return null; + var r = n.match(/([\(\[\{])|([\)\]\}])/); + return r ? r[1] ? this.$findClosingBracket(r[1], e) : this.$findOpeningBracket(r[2], e) : null + }, this.getBracketRange = function(e) { + var t = this.getLine(e.row), + n = !0, + r, s = t.charAt(e.column - 1), + o = s && s.match(/([\(\[\{])|([\)\]\}])/); + o || (s = t.charAt(e.column), e = { + row: e.row, + column: e.column + 1 + }, o = s && s.match(/([\(\[\{])|([\)\]\}])/), n = !1); + if (!o) return null; + if (o[1]) { + var u = this.$findClosingBracket(o[1], e); + if (!u) return null; + r = i.fromPoints(e, u), n || (r.end.column++, r.start.column--), r.cursor = r.end + } else { + var u = this.$findOpeningBracket(o[2], e); + if (!u) return null; + r = i.fromPoints(u, e), n || (r.start.column++, r.end.column--), r.cursor = r.start + } + return r + }, this.$brackets = { + ")": "(", + "(": ")", + "]": "[", + "[": "]", + "{": "}", + "}": "{" + }, this.$findOpeningBracket = function(e, t, n) { + var i = this.$brackets[e], + s = 1, + o = new r(this, t.row, t.column), + u = o.getCurrentToken(); + u || (u = o.stepForward()); + if (!u) return; + n || (n = new RegExp("(\\.?" + u.type.replace(".", "\\.").replace("rparen", ".paren").replace(/\b(?:end)\b/, "(?:start|begin|end)") + ")+")); + var a = t.column - o.getCurrentTokenColumn() - 2, + f = u.value; + for (;;) { + while (a >= 0) { + var l = f.charAt(a); + if (l == i) { + s -= 1; + if (s == 0) return { + row: o.getCurrentTokenRow(), + column: a + o.getCurrentTokenColumn() + } + } else l == e && (s += 1); + a -= 1 + } + do u = o.stepBackward(); while (u && !n.test(u.type)); + if (u == null) break; + f = u.value, a = f.length - 1 + } + return null + }, this.$findClosingBracket = function(e, t, n) { + var i = this.$brackets[e], + s = 1, + o = new r(this, t.row, t.column), + u = o.getCurrentToken(); + u || (u = o.stepForward()); + if (!u) return; + n || (n = new RegExp("(\\.?" + u.type.replace(".", "\\.").replace("lparen", ".paren").replace(/\b(?:start|begin)\b/, "(?:start|begin|end)") + ")+")); + var a = t.column - o.getCurrentTokenColumn(); + for (;;) { + var f = u.value, + l = f.length; + while (a < l) { + var c = f.charAt(a); + if (c == i) { + s -= 1; + if (s == 0) return { + row: o.getCurrentTokenRow(), + column: a + o.getCurrentTokenColumn() + } + } else c == e && (s += 1); + a += 1 + } + do u = o.stepForward(); while (u && !n.test(u.type)); + if (u == null) break; + a = 0 + } + return null + } + } + var r = e("../token_iterator").TokenIterator, + i = e("../range").Range; + t.BracketMatch = s +}), define("ace/edit_session", ["require", "exports", "module", "ace/lib/oop", "ace/lib/lang", "ace/bidihandler", "ace/config", "ace/lib/event_emitter", "ace/selection", "ace/mode/text", "ace/range", "ace/document", "ace/background_tokenizer", "ace/search_highlight", "ace/edit_session/folding", "ace/edit_session/bracket_match"], function(e, t, n) { + "use strict"; + var r = e("./lib/oop"), + i = e("./lib/lang"), + s = e("./bidihandler").BidiHandler, + o = e("./config"), + u = e("./lib/event_emitter").EventEmitter, + a = e("./selection").Selection, + f = e("./mode/text").Mode, + l = e("./range").Range, + c = e("./document").Document, + h = e("./background_tokenizer").BackgroundTokenizer, + p = e("./search_highlight").SearchHighlight, + d = function(e, t) { + this.$breakpoints = [], this.$decorations = [], this.$frontMarkers = {}, this.$backMarkers = {}, this.$markerId = 1, this.$undoSelect = !0, this.$foldData = [], this.id = "session" + ++d.$uid, this.$foldData.toString = function() { + return this.join("\n") + }, this.on("changeFold", this.onChangeFold.bind(this)), this.$onChange = this.onChange.bind(this); + if (typeof e != "object" || !e.getLine) e = new c(e); + this.$bidiHandler = new s(this), this.setDocument(e), this.selection = new a(this), o.resetOptions(this), this.setMode(t), o._signal("session", this) + }; + d.$uid = 0, + function() { + function m(e) { + return e < 4352 ? !1 : e >= 4352 && e <= 4447 || e >= 4515 && e <= 4519 || e >= 4602 && e <= 4607 || e >= 9001 && e <= 9002 || e >= 11904 && e <= 11929 || e >= 11931 && e <= 12019 || e >= 12032 && e <= 12245 || e >= 12272 && e <= 12283 || e >= 12288 && e <= 12350 || e >= 12353 && e <= 12438 || e >= 12441 && e <= 12543 || e >= 12549 && e <= 12589 || e >= 12593 && e <= 12686 || e >= 12688 && e <= 12730 || e >= 12736 && e <= 12771 || e >= 12784 && e <= 12830 || e >= 12832 && e <= 12871 || e >= 12880 && e <= 13054 || e >= 13056 && e <= 19903 || e >= 19968 && e <= 42124 || e >= 42128 && e <= 42182 || e >= 43360 && e <= 43388 || e >= 44032 && e <= 55203 || e >= 55216 && e <= 55238 || e >= 55243 && e <= 55291 || e >= 63744 && e <= 64255 || e >= 65040 && e <= 65049 || e >= 65072 && e <= 65106 || e >= 65108 && e <= 65126 || e >= 65128 && e <= 65131 || e >= 65281 && e <= 65376 || e >= 65504 && e <= 65510 + } + r.implement(this, u), this.setDocument = function(e) { + this.doc && this.doc.removeListener("change", this.$onChange), this.doc = e, e.on("change", this.$onChange), this.bgTokenizer && this.bgTokenizer.setDocument(this.getDocument()), this.resetCaches() + }, this.getDocument = function() { + return this.doc + }, this.$resetRowCache = function(e) { + if (!e) { + this.$docRowCache = [], this.$screenRowCache = []; + return + } + var t = this.$docRowCache.length, + n = this.$getRowCacheIndex(this.$docRowCache, e) + 1; + t > n && (this.$docRowCache.splice(n, t), this.$screenRowCache.splice(n, t)) + }, this.$getRowCacheIndex = function(e, t) { + var n = 0, + r = e.length - 1; + while (n <= r) { + var i = n + r >> 1, + s = e[i]; + if (t > s) n = i + 1; + else { + if (!(t < s)) return i; + r = i - 1 + } + } + return n - 1 + }, this.resetCaches = function() { + this.$modified = !0, this.$wrapData = [], this.$rowLengthCache = [], this.$resetRowCache(0), this.bgTokenizer && this.bgTokenizer.start(0) + }, this.onChangeFold = function(e) { + var t = e.data; + this.$resetRowCache(t.start.row) + }, this.onChange = function(e) { + this.$modified = !0, this.$bidiHandler.onChange(e), this.$resetRowCache(e.start.row); + var t = this.$updateInternalDataOnChange(e); + !this.$fromUndo && this.$undoManager && !e.ignore && (this.$deltasDoc.push(e), t && t.length != 0 && this.$deltasFold.push({ + action: "removeFolds", + folds: t + }), this.$informUndoManager.schedule()), this.bgTokenizer && this.bgTokenizer.$updateOnChange(e), this._signal("change", e) + }, this.setValue = function(e) { + this.doc.setValue(e), this.selection.moveTo(0, 0), this.$resetRowCache(0), this.$deltas = [], this.$deltasDoc = [], this.$deltasFold = [], this.setUndoManager(this.$undoManager), this.getUndoManager().reset() + }, this.getValue = this.toString = function() { + return this.doc.getValue() + }, this.getSelection = function() { + return this.selection + }, this.getState = function(e) { + return this.bgTokenizer.getState(e) + }, this.getTokens = function(e) { + return this.bgTokenizer.getTokens(e) + }, this.getTokenAt = function(e, t) { + var n = this.bgTokenizer.getTokens(e), + r, i = 0; + if (t == null) { + var s = n.length - 1; + i = this.getLine(e).length + } else + for (var s = 0; s < n.length; s++) { + i += n[s].value.length; + if (i >= t) break + } + return r = n[s], r ? (r.index = s, r.start = i - r.value.length, r) : null + }, this.setUndoManager = function(e) { + this.$undoManager = e, this.$deltas = [], this.$deltasDoc = [], this.$deltasFold = [], this.$informUndoManager && this.$informUndoManager.cancel(); + if (e) { + var t = this; + this.$syncInformUndoManager = function() { + t.$informUndoManager.cancel(), t.$deltasFold.length && (t.$deltas.push({ + group: "fold", + deltas: t.$deltasFold + }), t.$deltasFold = []), t.$deltasDoc.length && (t.$deltas.push({ + group: "doc", + deltas: t.$deltasDoc + }), t.$deltasDoc = []), t.$deltas.length > 0 && e.execute({ + action: "aceupdate", + args: [t.$deltas, t], + merge: t.mergeUndoDeltas + }), t.mergeUndoDeltas = !1, t.$deltas = [] + }, this.$informUndoManager = i.delayedCall(this.$syncInformUndoManager) + } + }, this.markUndoGroup = function() { + this.$syncInformUndoManager && this.$syncInformUndoManager() + }, this.$defaultUndoManager = { + undo: function() {}, + redo: function() {}, + reset: function() {} + }, this.getUndoManager = function() { + return this.$undoManager || this.$defaultUndoManager + }, this.getTabString = function() { + return this.getUseSoftTabs() ? i.stringRepeat(" ", this.getTabSize()) : " " + }, this.setUseSoftTabs = function(e) { + this.setOption("useSoftTabs", e) + }, this.getUseSoftTabs = function() { + return this.$useSoftTabs && !this.$mode.$indentWithTabs + }, this.setTabSize = function(e) { + this.setOption("tabSize", e) + }, this.getTabSize = function() { + return this.$tabSize + }, this.isTabStop = function(e) { + return this.$useSoftTabs && e.column % this.$tabSize === 0 + }, this.setNavigateWithinSoftTabs = function(e) { + this.setOption("navigateWithinSoftTabs", e) + }, this.getNavigateWithinSoftTabs = function() { + return this.$navigateWithinSoftTabs + }, this.$overwrite = !1, this.setOverwrite = function(e) { + this.setOption("overwrite", e) + }, this.getOverwrite = function() { + return this.$overwrite + }, this.toggleOverwrite = function() { + this.setOverwrite(!this.$overwrite) + }, this.addGutterDecoration = function(e, t) { + this.$decorations[e] || (this.$decorations[e] = ""), this.$decorations[e] += " " + t, this._signal("changeBreakpoint", {}) + }, this.removeGutterDecoration = function(e, t) { + this.$decorations[e] = (this.$decorations[e] || "").replace(" " + t, ""), this._signal("changeBreakpoint", {}) + }, this.getBreakpoints = function() { + return this.$breakpoints + }, this.setBreakpoints = function(e) { + this.$breakpoints = []; + for (var t = 0; t < e.length; t++) this.$breakpoints[e[t]] = "ace_breakpoint"; + this._signal("changeBreakpoint", {}) + }, this.clearBreakpoints = function() { + this.$breakpoints = [], this._signal("changeBreakpoint", {}) + }, this.setBreakpoint = function(e, t) { + t === undefined && (t = "ace_breakpoint"), t ? this.$breakpoints[e] = t : delete this.$breakpoints[e], this._signal("changeBreakpoint", {}) + }, this.clearBreakpoint = function(e) { + delete this.$breakpoints[e], this._signal("changeBreakpoint", {}) + }, this.addMarker = function(e, t, n, r) { + var i = this.$markerId++, + s = { + range: e, + type: n || "line", + renderer: typeof n == "function" ? n : null, + clazz: t, + inFront: !!r, + id: i + }; + return r ? (this.$frontMarkers[i] = s, this._signal("changeFrontMarker")) : (this.$backMarkers[i] = s, this._signal("changeBackMarker")), i + }, this.addDynamicMarker = function(e, t) { + if (!e.update) return; + var n = this.$markerId++; + return e.id = n, e.inFront = !!t, t ? (this.$frontMarkers[n] = e, this._signal("changeFrontMarker")) : (this.$backMarkers[n] = e, this._signal("changeBackMarker")), e + }, this.removeMarker = function(e) { + var t = this.$frontMarkers[e] || this.$backMarkers[e]; + if (!t) return; + var n = t.inFront ? this.$frontMarkers : this.$backMarkers; + t && (delete n[e], this._signal(t.inFront ? "changeFrontMarker" : "changeBackMarker")) + }, this.getMarkers = function(e) { + return e ? this.$frontMarkers : this.$backMarkers + }, this.highlight = function(e) { + if (!this.$searchHighlight) { + var t = new p(null, "ace_selected-word", "text"); + this.$searchHighlight = this.addDynamicMarker(t) + } + this.$searchHighlight.setRegexp(e) + }, this.highlightLines = function(e, t, n, r) { + typeof t != "number" && (n = t, t = e), n || (n = "ace_step"); + var i = new l(e, 0, t, Infinity); + return i.id = this.addMarker(i, n, "fullLine", r), i + }, this.setAnnotations = function(e) { + this.$annotations = e, this._signal("changeAnnotation", {}) + }, this.getAnnotations = function() { + return this.$annotations || [] + }, this.clearAnnotations = function() { + this.setAnnotations([]) + }, this.$detectNewLine = function(e) { + var t = e.match(/^.*?(\r?\n)/m); + t ? this.$autoNewLine = t[1] : this.$autoNewLine = "\n" + }, this.getWordRange = function(e, t) { + var n = this.getLine(e), + r = !1; + t > 0 && (r = !!n.charAt(t - 1).match(this.tokenRe)), r || (r = !!n.charAt(t).match(this.tokenRe)); + if (r) var i = this.tokenRe; + else if (/^\s+$/.test(n.slice(t - 1, t + 1))) var i = /\s/; + else var i = this.nonTokenRe; + var s = t; + if (s > 0) { + do s--; while (s >= 0 && n.charAt(s).match(i)); + s++ + } + var o = t; + while (o < n.length && n.charAt(o).match(i)) o++; + return new l(e, s, e, o) + }, this.getAWordRange = function(e, t) { + var n = this.getWordRange(e, t), + r = this.getLine(n.end.row); + while (r.charAt(n.end.column).match(/[ \t]/)) n.end.column += 1; + return n + }, this.setNewLineMode = function(e) { + this.doc.setNewLineMode(e) + }, this.getNewLineMode = function() { + return this.doc.getNewLineMode() + }, this.setUseWorker = function(e) { + this.setOption("useWorker", e) + }, this.getUseWorker = function() { + return this.$useWorker + }, this.onReloadTokenizer = function(e) { + var t = e.data; + this.bgTokenizer.start(t.first), this._signal("tokenizerUpdate", e) + }, this.$modes = {}, this.$mode = null, this.$modeId = null, this.setMode = function(e, t) { + if (e && typeof e == "object") { + if (e.getTokenizer) return this.$onChangeMode(e); + var n = e, + r = n.path + } else r = e || "ace/mode/text"; + this.$modes["ace/mode/text"] || (this.$modes["ace/mode/text"] = new f); + if (this.$modes[r] && !n) { + this.$onChangeMode(this.$modes[r]), t && t(); + return + } + this.$modeId = r, o.loadModule(["mode", r], function(e) { + if (this.$modeId !== r) return t && t(); + this.$modes[r] && !n ? this.$onChangeMode(this.$modes[r]) : e && e.Mode && (e = new e.Mode(n), n || (this.$modes[r] = e, e.$id = r), this.$onChangeMode(e)), t && t() + }.bind(this)), this.$mode || this.$onChangeMode(this.$modes["ace/mode/text"], !0) + }, this.$onChangeMode = function(e, t) { + t || (this.$modeId = e.$id); + if (this.$mode === e) return; + this.$mode = e, this.$stopWorker(), this.$useWorker && this.$startWorker(); + var n = e.getTokenizer(); + if (n.addEventListener !== undefined) { + var r = this.onReloadTokenizer.bind(this); + n.addEventListener("update", r) + } + if (!this.bgTokenizer) { + this.bgTokenizer = new h(n); + var i = this; + this.bgTokenizer.addEventListener("update", function(e) { + i._signal("tokenizerUpdate", e) + }) + } else this.bgTokenizer.setTokenizer(n); + this.bgTokenizer.setDocument(this.getDocument()), this.tokenRe = e.tokenRe, this.nonTokenRe = e.nonTokenRe, t || (e.attachToSession && e.attachToSession(this), this.$options.wrapMethod.set.call(this, this.$wrapMethod), this.$setFolding(e.foldingRules), this.bgTokenizer.start(0), this._emit("changeMode")) + }, this.$stopWorker = function() { + this.$worker && (this.$worker.terminate(), this.$worker = null) + }, this.$startWorker = function() { + try { + this.$worker = this.$mode.createWorker(this) + } catch (e) { + o.warn("Could not load worker", e), this.$worker = null + } + }, this.getMode = function() { + return this.$mode + }, this.$scrollTop = 0, this.setScrollTop = function(e) { + if (this.$scrollTop === e || isNaN(e)) return; + this.$scrollTop = e, this._signal("changeScrollTop", e) + }, this.getScrollTop = function() { + return this.$scrollTop + }, this.$scrollLeft = 0, this.setScrollLeft = function(e) { + if (this.$scrollLeft === e || isNaN(e)) return; + this.$scrollLeft = e, this._signal("changeScrollLeft", e) + }, this.getScrollLeft = function() { + return this.$scrollLeft + }, this.getScreenWidth = function() { + return this.$computeWidth(), this.lineWidgets ? Math.max(this.getLineWidgetMaxWidth(), this.screenWidth) : this.screenWidth + }, this.getLineWidgetMaxWidth = function() { + if (this.lineWidgetsWidth != null) return this.lineWidgetsWidth; + var e = 0; + return this.lineWidgets.forEach(function(t) { + t && t.screenWidth > e && (e = t.screenWidth) + }), this.lineWidgetWidth = e + }, this.$computeWidth = function(e) { + if (this.$modified || e) { + this.$modified = !1; + if (this.$useWrapMode) return this.screenWidth = this.$wrapLimit; + var t = this.doc.getAllLines(), + n = this.$rowLengthCache, + r = 0, + i = 0, + s = this.$foldData[i], + o = s ? s.start.row : Infinity, + u = t.length; + for (var a = 0; a < u; a++) { + if (a > o) { + a = s.end.row + 1; + if (a >= u) break; + s = this.$foldData[i++], o = s ? s.start.row : Infinity + } + n[a] == null && (n[a] = this.$getStringScreenWidth(t[a])[0]), n[a] > r && (r = n[a]) + } + this.screenWidth = r + } + }, this.getLine = function(e) { + return this.doc.getLine(e) + }, this.getLines = function(e, t) { + return this.doc.getLines(e, t) + }, this.getLength = function() { + return this.doc.getLength() + }, this.getTextRange = function(e) { + return this.doc.getTextRange(e || this.selection.getRange()) + }, this.insert = function(e, t) { + return this.doc.insert(e, t) + }, this.remove = function(e) { + return this.doc.remove(e) + }, this.removeFullLines = function(e, t) { + return this.doc.removeFullLines(e, t) + }, this.undoChanges = function(e, t) { + if (!e.length) return; + this.$fromUndo = !0; + var n = null; + for (var r = e.length - 1; r != -1; r--) { + var i = e[r]; + i.group == "doc" ? (this.doc.revertDeltas(i.deltas), n = this.$getUndoSelection(i.deltas, !0, n)) : i.deltas.forEach(function(e) { + this.addFolds(e.folds) + }, this) + } + return this.$fromUndo = !1, n && this.$undoSelect && !t && this.selection.setSelectionRange(n), n + }, this.redoChanges = function(e, t) { + if (!e.length) return; + this.$fromUndo = !0; + var n = null; + for (var r = 0; r < e.length; r++) { + var i = e[r]; + i.group == "doc" && (this.doc.applyDeltas(i.deltas), n = this.$getUndoSelection(i.deltas, !1, n)) + } + return this.$fromUndo = !1, n && this.$undoSelect && !t && this.selection.setSelectionRange(n), n + }, this.setUndoSelect = function(e) { + this.$undoSelect = e + }, this.$getUndoSelection = function(e, t, n) { + function r(e) { + return t ? e.action !== "insert" : e.action === "insert" + } + var i = e[0], + s, o, u = !1; + r(i) ? (s = l.fromPoints(i.start, i.end), u = !0) : (s = l.fromPoints(i.start, i.start), u = !1); + for (var a = 1; a < e.length; a++) i = e[a], r(i) ? (o = i.start, s.compare(o.row, o.column) == -1 && s.setStart(o), o = i.end, s.compare(o.row, o.column) == 1 && s.setEnd(o), u = !0) : (o = i.start, s.compare(o.row, o.column) == -1 && (s = l.fromPoints(i.start, i.start)), u = !1); + if (n != null) { + l.comparePoints(n.start, s.start) === 0 && (n.start.column += s.end.column - s.start.column, n.end.column += s.end.column - s.start.column); + var f = n.compareRange(s); + f == 1 ? s.setStart(n.start) : f == -1 && s.setEnd(n.end) + } + return s + }, this.replace = function(e, t) { + return this.doc.replace(e, t) + }, this.moveText = function(e, t, n) { + var r = this.getTextRange(e), + i = this.getFoldsInRange(e), + s = l.fromPoints(t, t); + if (!n) { + this.remove(e); + var o = e.start.row - e.end.row, + u = o ? -e.end.column : e.start.column - e.end.column; + u && (s.start.row == e.end.row && s.start.column > e.end.column && (s.start.column += u), s.end.row == e.end.row && s.end.column > e.end.column && (s.end.column += u)), o && s.start.row >= e.end.row && (s.start.row += o, s.end.row += o) + } + s.end = this.insert(s.start, r); + if (i.length) { + var a = e.start, + f = s.start, + o = f.row - a.row, + u = f.column - a.column; + this.addFolds(i.map(function(e) { + return e = e.clone(), e.start.row == a.row && (e.start.column += u), e.end.row == a.row && (e.end.column += u), e.start.row += o, e.end.row += o, e + })) + } + return s + }, this.indentRows = function(e, t, n) { + n = n.replace(/\t/g, this.getTabString()); + for (var r = e; r <= t; r++) this.doc.insertInLine({ + row: r, + column: 0 + }, n) + }, this.outdentRows = function(e) { + var t = e.collapseRows(), + n = new l(0, 0, 0, 0), + r = this.getTabSize(); + for (var i = t.start.row; i <= t.end.row; ++i) { + var s = this.getLine(i); + n.start.row = i, n.end.row = i; + for (var o = 0; o < r; ++o) + if (s.charAt(o) != " ") break; + o < r && s.charAt(o) == " " ? (n.start.column = o, n.end.column = o + 1) : (n.start.column = 0, n.end.column = o), this.remove(n) + } + }, this.$moveLines = function(e, t, n) { + e = this.getRowFoldStart(e), t = this.getRowFoldEnd(t); + if (n < 0) { + var r = this.getRowFoldStart(e + n); + if (r < 0) return 0; + var i = r - e + } else if (n > 0) { + var r = this.getRowFoldEnd(t + n); + if (r > this.doc.getLength() - 1) return 0; + var i = r - t + } else { + e = this.$clipRowToDocument(e), t = this.$clipRowToDocument(t); + var i = t - e + 1 + } + var s = new l(e, 0, t, Number.MAX_VALUE), + o = this.getFoldsInRange(s).map(function(e) { + return e = e.clone(), e.start.row += i, e.end.row += i, e + }), + u = n == 0 ? this.doc.getLines(e, t) : this.doc.removeFullLines(e, t); + return this.doc.insertFullLines(e + i, u), o.length && this.addFolds(o), i + }, this.moveLinesUp = function(e, t) { + return this.$moveLines(e, t, -1) + }, this.moveLinesDown = function(e, t) { + return this.$moveLines(e, t, 1) + }, this.duplicateLines = function(e, t) { + return this.$moveLines(e, t, 0) + }, this.$clipRowToDocument = function(e) { + return Math.max(0, Math.min(e, this.doc.getLength() - 1)) + }, this.$clipColumnToRow = function(e, t) { + return t < 0 ? 0 : Math.min(this.doc.getLine(e).length, t) + }, this.$clipPositionToDocument = function(e, t) { + t = Math.max(0, t); + if (e < 0) e = 0, t = 0; + else { + var n = this.doc.getLength(); + e >= n ? (e = n - 1, t = this.doc.getLine(n - 1).length) : t = Math.min(this.doc.getLine(e).length, t) + } + return { + row: e, + column: t + } + }, this.$clipRangeToDocument = function(e) { + e.start.row < 0 ? (e.start.row = 0, e.start.column = 0) : e.start.column = this.$clipColumnToRow(e.start.row, e.start.column); + var t = this.doc.getLength() - 1; + return e.end.row > t ? (e.end.row = t, e.end.column = this.doc.getLine(t).length) : e.end.column = this.$clipColumnToRow(e.end.row, e.end.column), e + }, this.$wrapLimit = 80, this.$useWrapMode = !1, this.$wrapLimitRange = { + min: null, + max: null + }, this.setUseWrapMode = function(e) { + if (e != this.$useWrapMode) { + this.$useWrapMode = e, this.$modified = !0, this.$resetRowCache(0); + if (e) { + var t = this.getLength(); + this.$wrapData = Array(t), this.$updateWrapData(0, t - 1) + } + this._signal("changeWrapMode") + } + }, this.getUseWrapMode = function() { + return this.$useWrapMode + }, this.setWrapLimitRange = function(e, t) { + if (this.$wrapLimitRange.min !== e || this.$wrapLimitRange.max !== t) this.$wrapLimitRange = { + min: e, + max: t + }, this.$modified = !0, this.$bidiHandler.markAsDirty(), this.$useWrapMode && this._signal("changeWrapMode") + }, this.adjustWrapLimit = function(e, t) { + var n = this.$wrapLimitRange; + n.max < 0 && (n = { + min: t, + max: t + }); + var r = this.$constrainWrapLimit(e, n.min, n.max); + return r != this.$wrapLimit && r > 1 ? (this.$wrapLimit = r, this.$modified = !0, this.$useWrapMode && (this.$updateWrapData(0, this.getLength() - 1), this.$resetRowCache(0), this._signal("changeWrapLimit")), !0) : !1 + }, this.$constrainWrapLimit = function(e, t, n) { + return t && (e = Math.max(t, e)), n && (e = Math.min(n, e)), e + }, this.getWrapLimit = function() { + return this.$wrapLimit + }, this.setWrapLimit = function(e) { + this.setWrapLimitRange(e, e) + }, this.getWrapLimitRange = function() { + return { + min: this.$wrapLimitRange.min, + max: this.$wrapLimitRange.max + } + }, this.$updateInternalDataOnChange = function(e) { + var t = this.$useWrapMode, + n = e.action, + r = e.start, + i = e.end, + s = r.row, + o = i.row, + u = o - s, + a = null; + this.$updating = !0; + if (u != 0) + if (n === "remove") { + this[t ? "$wrapData" : "$rowLengthCache"].splice(s, u); + var f = this.$foldData; + a = this.getFoldsInRange(e), this.removeFolds(a); + var l = this.getFoldLine(i.row), + c = 0; + if (l) { + l.addRemoveChars(i.row, i.column, r.column - i.column), l.shiftRow(-u); + var h = this.getFoldLine(s); + h && h !== l && (h.merge(l), l = h), c = f.indexOf(l) + 1 + } + for (c; c < f.length; c++) { + var l = f[c]; + l.start.row >= i.row && l.shiftRow(-u) + } + o = s + } else { + var p = Array(u); + p.unshift(s, 0); + var d = t ? this.$wrapData : this.$rowLengthCache; + d.splice.apply(d, p); + var f = this.$foldData, + l = this.getFoldLine(s), + c = 0; + if (l) { + var v = l.range.compareInside(r.row, r.column); + v == 0 ? (l = l.split(r.row, r.column), l && (l.shiftRow(u), l.addRemoveChars(o, 0, i.column - r.column))) : v == -1 && (l.addRemoveChars(s, 0, i.column - r.column), l.shiftRow(u)), c = f.indexOf(l) + 1 + } + for (c; c < f.length; c++) { + var l = f[c]; + l.start.row >= s && l.shiftRow(u) + } + } + else { + u = Math.abs(e.start.column - e.end.column), n === "remove" && (a = this.getFoldsInRange(e), this.removeFolds(a), u = -u); + var l = this.getFoldLine(s); + l && l.addRemoveChars(s, r.column, u) + } + return t && this.$wrapData.length != this.doc.getLength() && console.error("doc.getLength() and $wrapData.length have to be the same!"), this.$updating = !1, t ? this.$updateWrapData(s, o) : this.$updateRowLengthCache(s, o), a + }, this.$updateRowLengthCache = function(e, t, n) { + this.$rowLengthCache[e] = null, this.$rowLengthCache[t] = null + }, this.$updateWrapData = function(e, t) { + var r = this.doc.getAllLines(), + i = this.getTabSize(), + o = this.$wrapData, + u = this.$wrapLimit, + a, f, l = e; + t = Math.min(t, r.length - 1); + while (l <= t) f = this.getFoldLine(l, f), f ? (a = [], f.walk(function(e, t, i, o) { + var u; + if (e != null) { + u = this.$getDisplayTokens(e, a.length), u[0] = n; + for (var f = 1; f < u.length; f++) u[f] = s + } else u = this.$getDisplayTokens(r[t].substring(o, i), a.length); + a = a.concat(u) + }.bind(this), f.end.row, r[f.end.row].length + 1), o[f.start.row] = this.$computeWrapSplits(a, u, i), l = f.end.row + 1) : (a = this.$getDisplayTokens(r[l]), o[l] = this.$computeWrapSplits(a, u, i), l++) + }; + var e = 1, + t = 2, + n = 3, + s = 4, + a = 9, + c = 10, + d = 11, + v = 12; + this.$computeWrapSplits = function(e, r, i) { + function g() { + var t = 0; + if (m === 0) return t; + if (p) + for (var n = 0; n < e.length; n++) { + var r = e[n]; + if (r == c) t += 1; + else { + if (r != d) { + if (r == v) continue; + break + } + t += i + } + } + return h && p !== !1 && (t += i), Math.min(t, m) + } + + function y(t) { + var n = e.slice(f, t), + r = n.length; + n.join("").replace(/12/g, function() { + r -= 1 + }).replace(/2/g, function() { + r -= 1 + }), o.length || (b = g(), o.indent = b), l += r, o.push(l), f = t + } + if (e.length == 0) return []; + var o = [], + u = e.length, + f = 0, + l = 0, + h = this.$wrapAsCode, + p = this.$indentedSoftWrap, + m = r <= Math.max(2 * i, 8) || p === !1 ? 0 : Math.floor(r / 2), + b = 0; + while (u - f > r - b) { + var w = f + r - b; + if (e[w - 1] >= c && e[w] >= c) { + y(w); + continue + } + if (e[w] == n || e[w] == s) { + for (w; w != f - 1; w--) + if (e[w] == n) break; + if (w > f) { + y(w); + continue + } + w = f + r; + for (w; w < e.length; w++) + if (e[w] != s) break; + if (w == e.length) break; + y(w); + continue + } + var E = Math.max(w - (r - (r >> 2)), f - 1); + while (w > E && e[w] < n) w--; + if (h) { + while (w > E && e[w] < n) w--; + while (w > E && e[w] == a) w-- + } else + while (w > E && e[w] < c) w--; + if (w > E) { + y(++w); + continue + } + w = f + r, e[w] == t && w--, y(w - b) + } + return o + }, this.$getDisplayTokens = function(n, r) { + var i = [], + s; + r = r || 0; + for (var o = 0; o < n.length; o++) { + var u = n.charCodeAt(o); + if (u == 9) { + s = this.getScreenTabSize(i.length + r), i.push(d); + for (var f = 1; f < s; f++) i.push(v) + } else u == 32 ? i.push(c) : u > 39 && u < 48 || u > 57 && u < 64 ? i.push(a) : u >= 4352 && m(u) ? i.push(e, t) : i.push(e) + } + return i + }, this.$getStringScreenWidth = function(e, t, n) { + if (t == 0) return [0, 0]; + t == null && (t = Infinity), n = n || 0; + var r, i; + for (i = 0; i < e.length; i++) { + r = e.charCodeAt(i), r == 9 ? n += this.getScreenTabSize(n) : r >= 4352 && m(r) ? n += 2 : n += 1; + if (n > t) break + } + return [n, i] + }, this.lineWidgets = null, this.getRowLength = function(e) { + if (this.lineWidgets) var t = this.lineWidgets[e] && this.lineWidgets[e].rowCount || 0; + else t = 0; + return !this.$useWrapMode || !this.$wrapData[e] ? 1 + t : this.$wrapData[e].length + 1 + t + }, this.getRowLineCount = function(e) { + return !this.$useWrapMode || !this.$wrapData[e] ? 1 : this.$wrapData[e].length + 1 + }, this.getRowWrapIndent = function(e) { + if (this.$useWrapMode) { + var t = this.screenToDocumentPosition(e, Number.MAX_VALUE), + n = this.$wrapData[t.row]; + return n.length && n[0] < t.column ? n.indent : 0 + } + return 0 + }, this.getScreenLastRowColumn = function(e) { + var t = this.screenToDocumentPosition(e, Number.MAX_VALUE); + return this.documentToScreenColumn(t.row, t.column) + }, this.getDocumentLastRowColumn = function(e, t) { + var n = this.documentToScreenRow(e, t); + return this.getScreenLastRowColumn(n) + }, this.getDocumentLastRowColumnPosition = function(e, t) { + var n = this.documentToScreenRow(e, t); + return this.screenToDocumentPosition(n, Number.MAX_VALUE / 10) + }, this.getRowSplitData = function(e) { + return this.$useWrapMode ? this.$wrapData[e] : undefined + }, this.getScreenTabSize = function(e) { + return this.$tabSize - e % this.$tabSize + }, this.screenToDocumentRow = function(e, t) { + return this.screenToDocumentPosition(e, t).row + }, this.screenToDocumentColumn = function(e, t) { + return this.screenToDocumentPosition(e, t).column + }, this.screenToDocumentPosition = function(e, t, n) { + if (e < 0) return { + row: 0, + column: 0 + }; + var r, i = 0, + s = 0, + o, u = 0, + a = 0, + f = this.$screenRowCache, + l = this.$getRowCacheIndex(f, e), + c = f.length; + if (c && l >= 0) var u = f[l], + i = this.$docRowCache[l], + h = e > f[c - 1]; + else var h = !c; + var p = this.getLength() - 1, + d = this.getNextFoldLine(i), + v = d ? d.start.row : Infinity; + while (u <= e) { + a = this.getRowLength(i); + if (u + a > e || i >= p) break; + u += a, i++, i > v && (i = d.end.row + 1, d = this.getNextFoldLine(i, d), v = d ? d.start.row : Infinity), h && (this.$docRowCache.push(i), this.$screenRowCache.push(u)) + } + if (d && d.start.row <= i) r = this.getFoldDisplayLine(d), i = d.start.row; + else { + if (u + a <= e || i > p) return { + row: p, + column: this.getLine(p).length + }; + r = this.getLine(i), d = null + } + var m = 0, + g = Math.floor(e - u); + if (this.$useWrapMode) { + var y = this.$wrapData[i]; + y && (o = y[g], g > 0 && y.length && (m = y.indent, s = y[g - 1] || y[y.length - 1], r = r.substring(s))) + } + return n !== undefined && this.$bidiHandler.isBidiRow(u + g, i, g) && (t = this.$bidiHandler.offsetToCol(n)), s += this.$getStringScreenWidth(r, t - m)[1], this.$useWrapMode && s >= o && (s = o - 1), d ? d.idxToPosition(s) : { + row: i, + column: s + } + }, this.documentToScreenPosition = function(e, t) { + if (typeof t == "undefined") var n = this.$clipPositionToDocument(e.row, e.column); + else n = this.$clipPositionToDocument(e, t); + e = n.row, t = n.column; + var r = 0, + i = null, + s = null; + s = this.getFoldAt(e, t, 1), s && (e = s.start.row, t = s.start.column); + var o, u = 0, + a = this.$docRowCache, + f = this.$getRowCacheIndex(a, e), + l = a.length; + if (l && f >= 0) var u = a[f], + r = this.$screenRowCache[f], + c = e > a[l - 1]; + else var c = !l; + var h = this.getNextFoldLine(u), + p = h ? h.start.row : Infinity; + while (u < e) { + if (u >= p) { + o = h.end.row + 1; + if (o > e) break; + h = this.getNextFoldLine(o, h), p = h ? h.start.row : Infinity + } else o = u + 1; + r += this.getRowLength(u), u = o, c && (this.$docRowCache.push(u), this.$screenRowCache.push(r)) + } + var d = ""; + h && u >= p ? (d = this.getFoldDisplayLine(h, e, t), i = h.start.row) : (d = this.getLine(e).substring(0, t), i = e); + var v = 0; + if (this.$useWrapMode) { + var m = this.$wrapData[i]; + if (m) { + var g = 0; + while (d.length >= m[g]) r++, g++; + d = d.substring(m[g - 1] || 0, d.length), v = g > 0 ? m.indent : 0 + } + } + return { + row: r, + column: v + this.$getStringScreenWidth(d)[0] + } + }, this.documentToScreenColumn = function(e, t) { + return this.documentToScreenPosition(e, t).column + }, this.documentToScreenRow = function(e, t) { + return this.documentToScreenPosition(e, t).row + }, this.getScreenLength = function() { + var e = 0, + t = null; + if (!this.$useWrapMode) { + e = this.getLength(); + var n = this.$foldData; + for (var r = 0; r < n.length; r++) t = n[r], e -= t.end.row - t.start.row + } else { + var i = this.$wrapData.length, + s = 0, + r = 0, + t = this.$foldData[r++], + o = t ? t.start.row : Infinity; + while (s < i) { + var u = this.$wrapData[s]; + e += u ? u.length + 1 : 1, s++, s > o && (s = t.end.row + 1, t = this.$foldData[r++], o = t ? t.start.row : Infinity) + } + } + return this.lineWidgets && (e += this.$getWidgetScreenLength()), e + }, this.$setFontMetrics = function(e) { + if (!this.$enableVarChar) return; + this.$getStringScreenWidth = function(t, n, r) { + if (n === 0) return [0, 0]; + n || (n = Infinity), r = r || 0; + var i, s; + for (s = 0; s < t.length; s++) { + i = t.charAt(s), i === " " ? r += this.getScreenTabSize(r) : r += e.getCharacterWidth(i); + if (r > n) break + } + return [r, s] + } + }, this.destroy = function() { + this.bgTokenizer && (this.bgTokenizer.setDocument(null), this.bgTokenizer = null), this.$stopWorker() + }, this.isFullWidth = m + }.call(d.prototype), e("./edit_session/folding").Folding.call(d.prototype), e("./edit_session/bracket_match").BracketMatch.call(d.prototype), o.defineOptions(d.prototype, "session", { + wrap: { + set: function(e) { + !e || e == "off" ? e = !1 : e == "free" ? e = !0 : e == "printMargin" ? e = -1 : typeof e == "string" && (e = parseInt(e, 10) || !1); + if (this.$wrap == e) return; + this.$wrap = e; + if (!e) this.setUseWrapMode(!1); + else { + var t = typeof e == "number" ? e : null; + this.setWrapLimitRange(t, t), this.setUseWrapMode(!0) + } + }, + get: function() { + return this.getUseWrapMode() ? this.$wrap == -1 ? "printMargin" : this.getWrapLimitRange().min ? this.$wrap : "free" : "off" + }, + handlesSet: !0 + }, + wrapMethod: { + set: function(e) { + e = e == "auto" ? this.$mode.type != "text" : e != "text", e != this.$wrapAsCode && (this.$wrapAsCode = e, this.$useWrapMode && (this.$modified = !0, this.$resetRowCache(0), this.$updateWrapData(0, this.getLength() - 1))) + }, + initialValue: "auto" + }, + indentedSoftWrap: { + initialValue: !0 + }, + firstLineNumber: { + set: function() { + this._signal("changeBreakpoint") + }, + initialValue: 1 + }, + useWorker: { + set: function(e) { + this.$useWorker = e, this.$stopWorker(), e && this.$startWorker() + }, + initialValue: !0 + }, + useSoftTabs: { + initialValue: !0 + }, + tabSize: { + set: function(e) { + if (isNaN(e) || this.$tabSize === e) return; + this.$modified = !0, this.$rowLengthCache = [], this.$tabSize = e, this._signal("changeTabSize") + }, + initialValue: 4, + handlesSet: !0 + }, + navigateWithinSoftTabs: { + initialValue: !1 + }, + overwrite: { + set: function(e) { + this._signal("changeOverwrite") + }, + initialValue: !1 + }, + newLineMode: { + set: function(e) { + this.doc.setNewLineMode(e) + }, + get: function() { + return this.doc.getNewLineMode() + }, + handlesSet: !0 + }, + mode: { + set: function(e) { + this.setMode(e) + }, + get: function() { + return this.$modeId + } + } + }), t.EditSession = d +}), define("ace/search", ["require", "exports", "module", "ace/lib/lang", "ace/lib/oop", "ace/range"], function(e, t, n) { + "use strict"; + + function u(e, t) { + function n(e) { + return /\w/.test(e) || t.regExp ? "\\b" : "" + } + return n(e[0]) + e + n(e[e.length - 1]) + } + var r = e("./lib/lang"), + i = e("./lib/oop"), + s = e("./range").Range, + o = function() { + this.$options = {} + }; + (function() { + this.set = function(e) { + return i.mixin(this.$options, e), this + }, this.getOptions = function() { + return r.copyObject(this.$options) + }, this.setOptions = function(e) { + this.$options = e + }, this.find = function(e) { + var t = this.$options, + n = this.$matchIterator(e, t); + if (!n) return !1; + var r = null; + return n.forEach(function(e, n, i, o) { + return r = new s(e, n, i, o), n == o && t.start && t.start.start && t.skipCurrent != 0 && r.isEqual(t.start) ? (r = null, !1) : !0 + }), r + }, this.findAll = function(e) { + var t = this.$options; + if (!t.needle) return []; + this.$assembleRegExp(t); + var n = t.range, + i = n ? e.getLines(n.start.row, n.end.row) : e.doc.getAllLines(), + o = [], + u = t.re; + if (t.$isMultiLine) { + var a = u.length, + f = i.length - a, + l; + e: for (var c = u.offset || 0; c <= f; c++) { + for (var h = 0; h < a; h++) + if (i[c + h].search(u[h]) == -1) continue e; + var p = i[c], + d = i[c + a - 1], + v = p.length - p.match(u[0])[0].length, + m = d.match(u[a - 1])[0].length; + if (l && l.end.row === c && l.end.column > v) continue; + o.push(l = new s(c, v, c + a - 1, m)), a > 2 && (c = c + a - 2) + } + } else + for (var g = 0; g < i.length; g++) { + var y = r.getMatchOffsets(i[g], u); + for (var h = 0; h < y.length; h++) { + var b = y[h]; + o.push(new s(g, b.offset, g, b.offset + b.length)) + } + } + if (n) { + var w = n.start.column, + E = n.start.column, + g = 0, + h = o.length - 1; + while (g < h && o[g].start.column < w && o[g].start.row == n.start.row) g++; + while (g < h && o[h].end.column > E && o[h].end.row == n.end.row) h--; + o = o.slice(g, h + 1); + for (g = 0, h = o.length; g < h; g++) o[g].start.row += n.start.row, o[g].end.row += n.start.row + } + return o + }, this.replace = function(e, t) { + var n = this.$options, + r = this.$assembleRegExp(n); + if (n.$isMultiLine) return t; + if (!r) return; + var i = r.exec(e); + if (!i || i[0].length != e.length) return null; + t = e.replace(r, t); + if (n.preserveCase) { + t = t.split(""); + for (var s = Math.min(e.length, e.length); s--;) { + var o = e[s]; + o && o.toLowerCase() != o ? t[s] = t[s].toUpperCase() : t[s] = t[s].toLowerCase() + } + t = t.join("") + } + return t + }, this.$assembleRegExp = function(e, t) { + if (e.needle instanceof RegExp) return e.re = e.needle; + var n = e.needle; + if (!e.needle) return e.re = !1; + e.regExp || (n = r.escapeRegExp(n)), e.wholeWord && (n = u(n, e)); + var i = e.caseSensitive ? "gm" : "gmi"; + e.$isMultiLine = !t && /[\n\r]/.test(n); + if (e.$isMultiLine) return e.re = this.$assembleMultilineRegExp(n, i); + try { + var s = new RegExp(n, i) + } catch (o) { + s = !1 + } + return e.re = s + }, this.$assembleMultilineRegExp = function(e, t) { + var n = e.replace(/\r\n|\r|\n/g, "$\n^").split("\n"), + r = []; + for (var i = 0; i < n.length; i++) try { + r.push(new RegExp(n[i], t)) + } catch (s) { + return !1 + } + return r + }, this.$matchIterator = function(e, t) { + var n = this.$assembleRegExp(t); + if (!n) return !1; + var r = t.backwards == 1, + i = t.skipCurrent != 0, + s = t.range, + o = t.start; + o || (o = s ? s[r ? "end" : "start"] : e.selection.getRange()), o.start && (o = o[i != r ? "end" : "start"]); + var u = s ? s.start.row : 0, + a = s ? s.end.row : e.getLength() - 1; + if (r) var f = function(e) { + var n = o.row; + if (c(n, o.column, e)) return; + for (n--; n >= u; n--) + if (c(n, Number.MAX_VALUE, e)) return; + if (t.wrap == 0) return; + for (n = a, u = o.row; n >= u; n--) + if (c(n, Number.MAX_VALUE, e)) return + }; + else var f = function(e) { + var n = o.row; + if (c(n, o.column, e)) return; + for (n += 1; n <= a; n++) + if (c(n, 0, e)) return; + if (t.wrap == 0) return; + for (n = u, a = o.row; n <= a; n++) + if (c(n, 0, e)) return + }; + if (t.$isMultiLine) var l = n.length, + c = function(t, i, s) { + var o = r ? t - l + 1 : t; + if (o < 0) return; + var u = e.getLine(o), + a = u.search(n[0]); + if (!r && a < i || a === -1) return; + for (var f = 1; f < l; f++) { + u = e.getLine(o + f); + if (u.search(n[f]) == -1) return + } + var c = u.match(n[l - 1])[0].length; + if (r && c > i) return; + if (s(o, a, o + l - 1, c)) return !0 + }; + else if (r) var c = function(t, r, i) { + var s = e.getLine(t), + o = [], + u, a = 0; + n.lastIndex = 0; + while (u = n.exec(s)) { + var f = u[0].length; + a = u.index; + if (!f) { + if (a >= s.length) break; + n.lastIndex = a += 1 + } + if (u.index + f > r) break; + o.push(u.index, f) + } + for (var l = o.length - 1; l >= 0; l -= 2) { + var c = o[l - 1], + f = o[l]; + if (i(t, c, t, c + f)) return !0 + } + }; + else var c = function(t, r, i) { + var s = e.getLine(t), + o, u = r; + n.lastIndex = r; + while (o = n.exec(s)) { + var a = o[0].length; + u = o.index; + if (i(t, u, t, u + a)) return !0; + if (!a) { + n.lastIndex = u += 1; + if (u >= s.length) return !1 + } + } + }; + return { + forEach: f + } + } + }).call(o.prototype), t.Search = o +}), define("ace/keyboard/hash_handler", ["require", "exports", "module", "ace/lib/keys", "ace/lib/useragent"], function(e, t, n) { + "use strict"; + + function o(e, t) { + this.platform = t || (i.isMac ? "mac" : "win"), this.commands = {}, this.commandKeyBinding = {}, this.addCommands(e), this.$singleCommand = !0 + } + + function u(e, t) { + o.call(this, e, t), this.$singleCommand = !1 + } + var r = e("../lib/keys"), + i = e("../lib/useragent"), + s = r.KEY_MODS; + u.prototype = o.prototype, + function() { + function e(e) { + return typeof e == "object" && e.bindKey && e.bindKey.position || (e.isDefault ? -100 : 0) + } + this.addCommand = function(e) { + this.commands[e.name] && this.removeCommand(e), this.commands[e.name] = e, e.bindKey && this._buildKeyHash(e) + }, this.removeCommand = function(e, t) { + var n = e && (typeof e == "string" ? e : e.name); + e = this.commands[n], t || delete this.commands[n]; + var r = this.commandKeyBinding; + for (var i in r) { + var s = r[i]; + if (s == e) delete r[i]; + else if (Array.isArray(s)) { + var o = s.indexOf(e); + o != -1 && (s.splice(o, 1), s.length == 1 && (r[i] = s[0])) + } + } + }, this.bindKey = function(e, t, n) { + typeof e == "object" && e && (n == undefined && (n = e.position), e = e[this.platform]); + if (!e) return; + if (typeof t == "function") return this.addCommand({ + exec: t, + bindKey: e, + name: t.name || e + }); + e.split("|").forEach(function(e) { + var r = ""; + if (e.indexOf(" ") != -1) { + var i = e.split(/\s+/); + e = i.pop(), i.forEach(function(e) { + var t = this.parseKeys(e), + n = s[t.hashId] + t.key; + r += (r ? " " : "") + n, this._addCommandToBinding(r, "chainKeys") + }, this), r += " " + } + var o = this.parseKeys(e), + u = s[o.hashId] + o.key; + this._addCommandToBinding(r + u, t, n) + }, this) + }, this._addCommandToBinding = function(t, n, r) { + var i = this.commandKeyBinding, + s; + if (!n) delete i[t]; + else if (!i[t] || this.$singleCommand) i[t] = n; + else { + Array.isArray(i[t]) ? (s = i[t].indexOf(n)) != -1 && i[t].splice(s, 1) : i[t] = [i[t]], typeof r != "number" && (r = e(n)); + var o = i[t]; + for (s = 0; s < o.length; s++) { + var u = o[s], + a = e(u); + if (a > r) break + } + o.splice(s, 0, n) + } + }, this.addCommands = function(e) { + e && Object.keys(e).forEach(function(t) { + var n = e[t]; + if (!n) return; + if (typeof n == "string") return this.bindKey(n, t); + typeof n == "function" && (n = { + exec: n + }); + if (typeof n != "object") return; + n.name || (n.name = t), this.addCommand(n) + }, this) + }, this.removeCommands = function(e) { + Object.keys(e).forEach(function(t) { + this.removeCommand(e[t]) + }, this) + }, this.bindKeys = function(e) { + Object.keys(e).forEach(function(t) { + this.bindKey(t, e[t]) + }, this) + }, this._buildKeyHash = function(e) { + this.bindKey(e.bindKey, e) + }, this.parseKeys = function(e) { + var t = e.toLowerCase().split(/[\-\+]([\-\+])?/).filter(function(e) { + return e + }), + n = t.pop(), + i = r[n]; + if (r.FUNCTION_KEYS[i]) n = r.FUNCTION_KEYS[i].toLowerCase(); + else { + if (!t.length) return { + key: n, + hashId: -1 + }; + if (t.length == 1 && t[0] == "shift") return { + key: n.toUpperCase(), + hashId: -1 + } + } + var s = 0; + for (var o = t.length; o--;) { + var u = r.KEY_MODS[t[o]]; + if (u == null) return typeof console != "undefined" && console.error("invalid modifier " + t[o] + " in " + e), !1; + s |= u + } + return { + key: n, + hashId: s + } + }, this.findKeyCommand = function(t, n) { + var r = s[t] + n; + return this.commandKeyBinding[r] + }, this.handleKeyboard = function(e, t, n, r) { + if (r < 0) return; + var i = s[t] + n, + o = this.commandKeyBinding[i]; + e.$keyChain && (e.$keyChain += " " + i, o = this.commandKeyBinding[e.$keyChain] || o); + if (o) + if (o == "chainKeys" || o[o.length - 1] == "chainKeys") return e.$keyChain = e.$keyChain || i, { + command: "null" + }; + if (e.$keyChain) + if (!!t && t != 4 || n.length != 1) { + if (t == -1 || r > 0) e.$keyChain = "" + } else e.$keyChain = e.$keyChain.slice(0, -i.length - 1); + return { + command: o + } + }, this.getStatusText = function(e, t) { + return t.$keyChain || "" + } + }.call(o.prototype), t.HashHandler = o, t.MultiHashHandler = u +}), define("ace/commands/command_manager", ["require", "exports", "module", "ace/lib/oop", "ace/keyboard/hash_handler", "ace/lib/event_emitter"], function(e, t, n) { + "use strict"; + var r = e("../lib/oop"), + i = e("../keyboard/hash_handler").MultiHashHandler, + s = e("../lib/event_emitter").EventEmitter, + o = function(e, t) { + i.call(this, t, e), this.byName = this.commands, this.setDefaultHandler("exec", function(e) { + return e.command.exec(e.editor, e.args || {}) + }) + }; + r.inherits(o, i), + function() { + r.implement(this, s), this.exec = function(e, t, n) { + if (Array.isArray(e)) { + for (var r = e.length; r--;) + if (this.exec(e[r], t, n)) return !0; + return !1 + } + typeof e == "string" && (e = this.commands[e]); + if (!e) return !1; + if (t && t.$readOnly && !e.readOnly) return !1; + if (e.isAvailable && !e.isAvailable(t)) return !1; + var i = { + editor: t, + command: e, + args: n + }; + return i.returnValue = this._emit("exec", i), this._signal("afterExec", i), i.returnValue === !1 ? !1 : !0 + }, this.toggleRecording = function(e) { + if (this.$inReplay) return; + return e && e._emit("changeStatus"), this.recording ? (this.macro.pop(), this.removeEventListener("exec", this.$addCommandToMacro), this.macro.length || (this.macro = this.oldMacro), this.recording = !1) : (this.$addCommandToMacro || (this.$addCommandToMacro = function(e) { + this.macro.push([e.command, e.args]) + }.bind(this)), this.oldMacro = this.macro, this.macro = [], this.on("exec", this.$addCommandToMacro), this.recording = !0) + }, this.replay = function(e) { + if (this.$inReplay || !this.macro) return; + if (this.recording) return this.toggleRecording(e); + try { + this.$inReplay = !0, this.macro.forEach(function(t) { + typeof t == "string" ? this.exec(t, e) : this.exec(t[0], e, t[1]) + }, this) + } finally { + this.$inReplay = !1 + } + }, this.trimMacro = function(e) { + return e.map(function(e) { + return typeof e[0] != "string" && (e[0] = e[0].name), e[1] || (e = e[0]), e + }) + } + }.call(o.prototype), t.CommandManager = o +}), define("ace/commands/default_commands", ["require", "exports", "module", "ace/lib/lang", "ace/config", "ace/range"], function(e, t, n) { + "use strict"; + + function o(e, t) { + return { + win: e, + mac: t + } + } + var r = e("../lib/lang"), + i = e("../config"), + s = e("../range").Range; + t.commands = [{ + name: "showSettingsMenu", + bindKey: o("Ctrl-,", "Command-,"), + exec: function(e) { + i.loadModule("ace/ext/settings_menu", function(t) { + t.init(e), e.showSettingsMenu() + }) + }, + readOnly: !0 + }, { + name: "goToNextError", + bindKey: o("Alt-E", "F4"), + exec: function(e) { + i.loadModule("ace/ext/error_marker", function(t) { + t.showErrorMarker(e, 1) + }) + }, + scrollIntoView: "animate", + readOnly: !0 + }, { + name: "goToPreviousError", + bindKey: o("Alt-Shift-E", "Shift-F4"), + exec: function(e) { + i.loadModule("ace/ext/error_marker", function(t) { + t.showErrorMarker(e, -1) + }) + }, + scrollIntoView: "animate", + readOnly: !0 + }, { + name: "selectall", + bindKey: o("Ctrl-A", "Command-A"), + exec: function(e) { + e.selectAll() + }, + readOnly: !0 + }, { + name: "centerselection", + bindKey: o(null, "Ctrl-L"), + exec: function(e) { + e.centerSelection() + }, + readOnly: !0 + }, { + name: "gotoline", + bindKey: o("Ctrl-L", "Command-L"), + exec: function(e) { + var t = parseInt(prompt("Enter line number:"), 10); + isNaN(t) || e.gotoLine(t) + }, + readOnly: !0 + }, { + name: "fold", + bindKey: o("Alt-L|Ctrl-F1", "Command-Alt-L|Command-F1"), + exec: function(e) { + e.session.toggleFold(!1) + }, + multiSelectAction: "forEach", + scrollIntoView: "center", + readOnly: !0 + }, { + name: "unfold", + bindKey: o("Alt-Shift-L|Ctrl-Shift-F1", "Command-Alt-Shift-L|Command-Shift-F1"), + exec: function(e) { + e.session.toggleFold(!0) + }, + multiSelectAction: "forEach", + scrollIntoView: "center", + readOnly: !0 + }, { + name: "toggleFoldWidget", + bindKey: o("F2", "F2"), + exec: function(e) { + e.session.toggleFoldWidget() + }, + multiSelectAction: "forEach", + scrollIntoView: "center", + readOnly: !0 + }, { + name: "toggleParentFoldWidget", + bindKey: o("Alt-F2", "Alt-F2"), + exec: function(e) { + e.session.toggleFoldWidget(!0) + }, + multiSelectAction: "forEach", + scrollIntoView: "center", + readOnly: !0 + }, { + name: "foldall", + bindKey: o(null, "Ctrl-Command-Option-0"), + exec: function(e) { + e.session.foldAll() + }, + scrollIntoView: "center", + readOnly: !0 + }, { + name: "foldOther", + bindKey: o("Alt-0", "Command-Option-0"), + exec: function(e) { + e.session.foldAll(), e.session.unfold(e.selection.getAllRanges()) + }, + scrollIntoView: "center", + readOnly: !0 + }, { + name: "unfoldall", + bindKey: o("Alt-Shift-0", "Command-Option-Shift-0"), + exec: function(e) { + e.session.unfold() + }, + scrollIntoView: "center", + readOnly: !0 + }, { + name: "findnext", + bindKey: o("Ctrl-K", "Command-G"), + exec: function(e) { + e.findNext() + }, + multiSelectAction: "forEach", + scrollIntoView: "center", + readOnly: !0 + }, { + name: "findprevious", + bindKey: o("Ctrl-Shift-K", "Command-Shift-G"), + exec: function(e) { + e.findPrevious() + }, + multiSelectAction: "forEach", + scrollIntoView: "center", + readOnly: !0 + }, { + name: "selectOrFindNext", + bindKey: o("Alt-K", "Ctrl-G"), + exec: function(e) { + e.selection.isEmpty() ? e.selection.selectWord() : e.findNext() + }, + readOnly: !0 + }, { + name: "selectOrFindPrevious", + bindKey: o("Alt-Shift-K", "Ctrl-Shift-G"), + exec: function(e) { + e.selection.isEmpty() ? e.selection.selectWord() : e.findPrevious() + }, + readOnly: !0 + }, { + name: "find", + bindKey: o("Ctrl-F", "Command-F"), + exec: function(e) { + i.loadModule("ace/ext/searchbox", function(t) { + t.Search(e) + }) + }, + readOnly: !0 + }, { + name: "overwrite", + bindKey: "Insert", + exec: function(e) { + e.toggleOverwrite() + }, + readOnly: !0 + }, { + name: "selecttostart", + bindKey: o("Ctrl-Shift-Home", "Command-Shift-Home|Command-Shift-Up"), + exec: function(e) { + e.getSelection().selectFileStart() + }, + multiSelectAction: "forEach", + readOnly: !0, + scrollIntoView: "animate", + aceCommandGroup: "fileJump" + }, { + name: "gotostart", + bindKey: o("Ctrl-Home", "Command-Home|Command-Up"), + exec: function(e) { + e.navigateFileStart() + }, + multiSelectAction: "forEach", + readOnly: !0, + scrollIntoView: "animate", + aceCommandGroup: "fileJump" + }, { + name: "selectup", + bindKey: o("Shift-Up", "Shift-Up|Ctrl-Shift-P"), + exec: function(e) { + e.getSelection().selectUp() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "golineup", + bindKey: o("Up", "Up|Ctrl-P"), + exec: function(e, t) { + e.navigateUp(t.times) + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selecttoend", + bindKey: o("Ctrl-Shift-End", "Command-Shift-End|Command-Shift-Down"), + exec: function(e) { + e.getSelection().selectFileEnd() + }, + multiSelectAction: "forEach", + readOnly: !0, + scrollIntoView: "animate", + aceCommandGroup: "fileJump" + }, { + name: "gotoend", + bindKey: o("Ctrl-End", "Command-End|Command-Down"), + exec: function(e) { + e.navigateFileEnd() + }, + multiSelectAction: "forEach", + readOnly: !0, + scrollIntoView: "animate", + aceCommandGroup: "fileJump" + }, { + name: "selectdown", + bindKey: o("Shift-Down", "Shift-Down|Ctrl-Shift-N"), + exec: function(e) { + e.getSelection().selectDown() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "golinedown", + bindKey: o("Down", "Down|Ctrl-N"), + exec: function(e, t) { + e.navigateDown(t.times) + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selectwordleft", + bindKey: o("Ctrl-Shift-Left", "Option-Shift-Left"), + exec: function(e) { + e.getSelection().selectWordLeft() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "gotowordleft", + bindKey: o("Ctrl-Left", "Option-Left"), + exec: function(e) { + e.navigateWordLeft() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selecttolinestart", + bindKey: o("Alt-Shift-Left", "Command-Shift-Left|Ctrl-Shift-A"), + exec: function(e) { + e.getSelection().selectLineStart() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "gotolinestart", + bindKey: o("Alt-Left|Home", "Command-Left|Home|Ctrl-A"), + exec: function(e) { + e.navigateLineStart() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selectleft", + bindKey: o("Shift-Left", "Shift-Left|Ctrl-Shift-B"), + exec: function(e) { + e.getSelection().selectLeft() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "gotoleft", + bindKey: o("Left", "Left|Ctrl-B"), + exec: function(e, t) { + e.navigateLeft(t.times) + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selectwordright", + bindKey: o("Ctrl-Shift-Right", "Option-Shift-Right"), + exec: function(e) { + e.getSelection().selectWordRight() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "gotowordright", + bindKey: o("Ctrl-Right", "Option-Right"), + exec: function(e) { + e.navigateWordRight() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selecttolineend", + bindKey: o("Alt-Shift-Right", "Command-Shift-Right|Shift-End|Ctrl-Shift-E"), + exec: function(e) { + e.getSelection().selectLineEnd() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "gotolineend", + bindKey: o("Alt-Right|End", "Command-Right|End|Ctrl-E"), + exec: function(e) { + e.navigateLineEnd() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selectright", + bindKey: o("Shift-Right", "Shift-Right"), + exec: function(e) { + e.getSelection().selectRight() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "gotoright", + bindKey: o("Right", "Right|Ctrl-F"), + exec: function(e, t) { + e.navigateRight(t.times) + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selectpagedown", + bindKey: "Shift-PageDown", + exec: function(e) { + e.selectPageDown() + }, + readOnly: !0 + }, { + name: "pagedown", + bindKey: o(null, "Option-PageDown"), + exec: function(e) { + e.scrollPageDown() + }, + readOnly: !0 + }, { + name: "gotopagedown", + bindKey: o("PageDown", "PageDown|Ctrl-V"), + exec: function(e) { + e.gotoPageDown() + }, + readOnly: !0 + }, { + name: "selectpageup", + bindKey: "Shift-PageUp", + exec: function(e) { + e.selectPageUp() + }, + readOnly: !0 + }, { + name: "pageup", + bindKey: o(null, "Option-PageUp"), + exec: function(e) { + e.scrollPageUp() + }, + readOnly: !0 + }, { + name: "gotopageup", + bindKey: "PageUp", + exec: function(e) { + e.gotoPageUp() + }, + readOnly: !0 + }, { + name: "scrollup", + bindKey: o("Ctrl-Up", null), + exec: function(e) { + e.renderer.scrollBy(0, -2 * e.renderer.layerConfig.lineHeight) + }, + readOnly: !0 + }, { + name: "scrolldown", + bindKey: o("Ctrl-Down", null), + exec: function(e) { + e.renderer.scrollBy(0, 2 * e.renderer.layerConfig.lineHeight) + }, + readOnly: !0 + }, { + name: "selectlinestart", + bindKey: "Shift-Home", + exec: function(e) { + e.getSelection().selectLineStart() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selectlineend", + bindKey: "Shift-End", + exec: function(e) { + e.getSelection().selectLineEnd() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "togglerecording", + bindKey: o("Ctrl-Alt-E", "Command-Option-E"), + exec: function(e) { + e.commands.toggleRecording(e) + }, + readOnly: !0 + }, { + name: "replaymacro", + bindKey: o("Ctrl-Shift-E", "Command-Shift-E"), + exec: function(e) { + e.commands.replay(e) + }, + readOnly: !0 + }, { + name: "jumptomatching", + bindKey: o("Ctrl-P", "Ctrl-P"), + exec: function(e) { + e.jumpToMatching() + }, + multiSelectAction: "forEach", + scrollIntoView: "animate", + readOnly: !0 + }, { + name: "selecttomatching", + bindKey: o("Ctrl-Shift-P", "Ctrl-Shift-P"), + exec: function(e) { + e.jumpToMatching(!0) + }, + multiSelectAction: "forEach", + scrollIntoView: "animate", + readOnly: !0 + }, { + name: "expandToMatching", + bindKey: o("Ctrl-Shift-M", "Ctrl-Shift-M"), + exec: function(e) { + e.jumpToMatching(!0, !0) + }, + multiSelectAction: "forEach", + scrollIntoView: "animate", + readOnly: !0 + }, { + name: "passKeysToBrowser", + bindKey: o(null, null), + exec: function() {}, + passEvent: !0, + readOnly: !0 + }, { + name: "copy", + exec: function(e) {}, + readOnly: !0 + }, { + name: "cut", + exec: function(e) { + var t = e.getSelectionRange(); + e._emit("cut", t), e.selection.isEmpty() || (e.session.remove(t), e.clearSelection()) + }, + scrollIntoView: "cursor", + multiSelectAction: "forEach" + }, { + name: "paste", + exec: function(e, t) { + e.$handlePaste(t) + }, + scrollIntoView: "cursor" + }, { + name: "removeline", + bindKey: o("Ctrl-D", "Command-D"), + exec: function(e) { + e.removeLines() + }, + scrollIntoView: "cursor", + multiSelectAction: "forEachLine" + }, { + name: "duplicateSelection", + bindKey: o("Ctrl-Shift-D", "Command-Shift-D"), + exec: function(e) { + e.duplicateSelection() + }, + scrollIntoView: "cursor", + multiSelectAction: "forEach" + }, { + name: "sortlines", + bindKey: o("Ctrl-Alt-S", "Command-Alt-S"), + exec: function(e) { + e.sortLines() + }, + scrollIntoView: "selection", + multiSelectAction: "forEachLine" + }, { + name: "togglecomment", + bindKey: o("Ctrl-/", "Command-/"), + exec: function(e) { + e.toggleCommentLines() + }, + multiSelectAction: "forEachLine", + scrollIntoView: "selectionPart" + }, { + name: "toggleBlockComment", + bindKey: o("Ctrl-Shift-/", "Command-Shift-/"), + exec: function(e) { + e.toggleBlockComment() + }, + multiSelectAction: "forEach", + scrollIntoView: "selectionPart" + }, { + name: "modifyNumberUp", + bindKey: o("Ctrl-Shift-Up", "Alt-Shift-Up"), + exec: function(e) { + e.modifyNumber(1) + }, + scrollIntoView: "cursor", + multiSelectAction: "forEach" + }, { + name: "modifyNumberDown", + bindKey: o("Ctrl-Shift-Down", "Alt-Shift-Down"), + exec: function(e) { + e.modifyNumber(-1) + }, + scrollIntoView: "cursor", + multiSelectAction: "forEach" + }, { + name: "replace", + bindKey: o("Ctrl-H", "Command-Option-F"), + exec: function(e) { + i.loadModule("ace/ext/searchbox", function(t) { + t.Search(e, !0) + }) + } + }, { + name: "undo", + bindKey: o("Ctrl-Z", "Command-Z"), + exec: function(e) { + e.undo() + } + }, { + name: "redo", + bindKey: o("Ctrl-Shift-Z|Ctrl-Y", "Command-Shift-Z|Command-Y"), + exec: function(e) { + e.redo() + } + }, { + name: "copylinesup", + bindKey: o("Alt-Shift-Up", "Command-Option-Up"), + exec: function(e) { + e.copyLinesUp() + }, + scrollIntoView: "cursor" + }, { + name: "movelinesup", + bindKey: o("Alt-Up", "Option-Up"), + exec: function(e) { + e.moveLinesUp() + }, + scrollIntoView: "cursor" + }, { + name: "copylinesdown", + bindKey: o("Alt-Shift-Down", "Command-Option-Down"), + exec: function(e) { + e.copyLinesDown() + }, + scrollIntoView: "cursor" + }, { + name: "movelinesdown", + bindKey: o("Alt-Down", "Option-Down"), + exec: function(e) { + e.moveLinesDown() + }, + scrollIntoView: "cursor" + }, { + name: "del", + bindKey: o("Delete", "Delete|Ctrl-D|Shift-Delete"), + exec: function(e) { + e.remove("right") + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "backspace", + bindKey: o("Shift-Backspace|Backspace", "Ctrl-Backspace|Shift-Backspace|Backspace|Ctrl-H"), + exec: function(e) { + e.remove("left") + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "cut_or_delete", + bindKey: o("Shift-Delete", null), + exec: function(e) { + if (!e.selection.isEmpty()) return !1; + e.remove("left") + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "removetolinestart", + bindKey: o("Alt-Backspace", "Command-Backspace"), + exec: function(e) { + e.removeToLineStart() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "removetolineend", + bindKey: o("Alt-Delete", "Ctrl-K|Command-Delete"), + exec: function(e) { + e.removeToLineEnd() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "removetolinestarthard", + bindKey: o("Ctrl-Shift-Backspace", null), + exec: function(e) { + var t = e.selection.getRange(); + t.start.column = 0, e.session.remove(t) + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "removetolineendhard", + bindKey: o("Ctrl-Shift-Delete", null), + exec: function(e) { + var t = e.selection.getRange(); + t.end.column = Number.MAX_VALUE, e.session.remove(t) + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "removewordleft", + bindKey: o("Ctrl-Backspace", "Alt-Backspace|Ctrl-Alt-Backspace"), + exec: function(e) { + e.removeWordLeft() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "removewordright", + bindKey: o("Ctrl-Delete", "Alt-Delete"), + exec: function(e) { + e.removeWordRight() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "outdent", + bindKey: o("Shift-Tab", "Shift-Tab"), + exec: function(e) { + e.blockOutdent() + }, + multiSelectAction: "forEach", + scrollIntoView: "selectionPart" + }, { + name: "indent", + bindKey: o("Tab", "Tab"), + exec: function(e) { + e.indent() + }, + multiSelectAction: "forEach", + scrollIntoView: "selectionPart" + }, { + name: "blockoutdent", + bindKey: o("Ctrl-[", "Ctrl-["), + exec: function(e) { + e.blockOutdent() + }, + multiSelectAction: "forEachLine", + scrollIntoView: "selectionPart" + }, { + name: "blockindent", + bindKey: o("Ctrl-]", "Ctrl-]"), + exec: function(e) { + e.blockIndent() + }, + multiSelectAction: "forEachLine", + scrollIntoView: "selectionPart" + }, { + name: "insertstring", + exec: function(e, t) { + e.insert(t) + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "inserttext", + exec: function(e, t) { + e.insert(r.stringRepeat(t.text || "", t.times || 1)) + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "splitline", + bindKey: o(null, "Ctrl-O"), + exec: function(e) { + e.splitLine() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "transposeletters", + bindKey: o("Alt-Shift-X", "Ctrl-T"), + exec: function(e) { + e.transposeLetters() + }, + multiSelectAction: function(e) { + e.transposeSelections(1) + }, + scrollIntoView: "cursor" + }, { + name: "touppercase", + bindKey: o("Ctrl-U", "Ctrl-U"), + exec: function(e) { + e.toUpperCase() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "tolowercase", + bindKey: o("Ctrl-Shift-U", "Ctrl-Shift-U"), + exec: function(e) { + e.toLowerCase() + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor" + }, { + name: "expandtoline", + bindKey: o("Ctrl-Shift-L", "Command-Shift-L"), + exec: function(e) { + var t = e.selection.getRange(); + t.start.column = t.end.column = 0, t.end.row++, e.selection.setRange(t, !1) + }, + multiSelectAction: "forEach", + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "joinlines", + bindKey: o(null, null), + exec: function(e) { + var t = e.selection.isBackwards(), + n = t ? e.selection.getSelectionLead() : e.selection.getSelectionAnchor(), + i = t ? e.selection.getSelectionAnchor() : e.selection.getSelectionLead(), + o = e.session.doc.getLine(n.row).length, + u = e.session.doc.getTextRange(e.selection.getRange()), + a = u.replace(/\n\s*/, " ").length, + f = e.session.doc.getLine(n.row); + for (var l = n.row + 1; l <= i.row + 1; l++) { + var c = r.stringTrimLeft(r.stringTrimRight(e.session.doc.getLine(l))); + c.length !== 0 && (c = " " + c), f += c + } + i.row + 1 < e.session.doc.getLength() - 1 && (f += e.session.doc.getNewLineCharacter()), e.clearSelection(), e.session.doc.replace(new s(n.row, 0, i.row + 2, 0), f), a > 0 ? (e.selection.moveCursorTo(n.row, n.column), e.selection.selectTo(n.row, n.column + a)) : (o = e.session.doc.getLine(n.row).length > o ? o + 1 : o, e.selection.moveCursorTo(n.row, o)) + }, + multiSelectAction: "forEach", + readOnly: !0 + }, { + name: "invertSelection", + bindKey: o(null, null), + exec: function(e) { + var t = e.session.doc.getLength() - 1, + n = e.session.doc.getLine(t).length, + r = e.selection.rangeList.ranges, + i = []; + r.length < 1 && (r = [e.selection.getRange()]); + for (var o = 0; o < r.length; o++) o == r.length - 1 && (r[o].end.row !== t || r[o].end.column !== n) && i.push(new s(r[o].end.row, r[o].end.column, t, n)), o === 0 ? (r[o].start.row !== 0 || r[o].start.column !== 0) && i.push(new s(0, 0, r[o].start.row, r[o].start.column)) : i.push(new s(r[o - 1].end.row, r[o - 1].end.column, r[o].start.row, r[o].start.column)); + e.exitMultiSelectMode(), e.clearSelection(); + for (var o = 0; o < i.length; o++) e.selection.addRange(i[o], !1) + }, + readOnly: !0, + scrollIntoView: "none" + }] +}), define("ace/editor", ["require", "exports", "module", "ace/lib/fixoldbrowsers", "ace/lib/oop", "ace/lib/dom", "ace/lib/lang", "ace/lib/useragent", "ace/keyboard/textinput", "ace/mouse/mouse_handler", "ace/mouse/fold_handler", "ace/keyboard/keybinding", "ace/edit_session", "ace/search", "ace/range", "ace/lib/event_emitter", "ace/commands/command_manager", "ace/commands/default_commands", "ace/config", "ace/token_iterator"], function(e, t, n) { + "use strict"; + e("./lib/fixoldbrowsers"); + var r = e("./lib/oop"), + i = e("./lib/dom"), + s = e("./lib/lang"), + o = e("./lib/useragent"), + u = e("./keyboard/textinput").TextInput, + a = e("./mouse/mouse_handler").MouseHandler, + f = e("./mouse/fold_handler").FoldHandler, + l = e("./keyboard/keybinding").KeyBinding, + c = e("./edit_session").EditSession, + h = e("./search").Search, + p = e("./range").Range, + d = e("./lib/event_emitter").EventEmitter, + v = e("./commands/command_manager").CommandManager, + m = e("./commands/default_commands").commands, + g = e("./config"), + y = e("./token_iterator").TokenIterator, + b = function(e, t) { + var n = e.getContainerElement(); + this.container = n, this.renderer = e, this.id = "editor" + ++b.$uid, this.commands = new v(o.isMac ? "mac" : "win", m), typeof document == "object" && (this.textInput = new u(e.getTextAreaContainer(), this), this.renderer.textarea = this.textInput.getElement(), this.$mouseHandler = new a(this), new f(this)), this.keyBinding = new l(this), this.$blockScrolling = 0, this.$search = (new h).set({ + wrap: !0 + }), this.$historyTracker = this.$historyTracker.bind(this), this.commands.on("exec", this.$historyTracker), this.$initOperationListeners(), this._$emitInputEvent = s.delayedCall(function() { + this._signal("input", {}), this.session && this.session.bgTokenizer && this.session.bgTokenizer.scheduleStart() + }.bind(this)), this.on("change", function(e, t) { + t._$emitInputEvent.schedule(31) + }), this.setSession(t || new c("")), g.resetOptions(this), g._signal("editor", this) + }; + b.$uid = 0, + function() { + r.implement(this, d), this.$initOperationListeners = function() { + function e(e) { + return e[e.length - 1] + } + this.selections = [], this.commands.on("exec", this.startOperation.bind(this), !0), this.commands.on("afterExec", this.endOperation.bind(this), !0), this.$opResetTimer = s.delayedCall(this.endOperation.bind(this)), this.on("change", function() { + this.curOp || this.startOperation(), this.curOp.docChanged = !0 + }.bind(this), !0), this.on("changeSelection", function() { + this.curOp || this.startOperation(), this.curOp.selectionChanged = !0 + }.bind(this), !0) + }, this.curOp = null, this.prevOp = {}, this.startOperation = function(e) { + if (this.curOp) { + if (!e || this.curOp.command) return; + this.prevOp = this.curOp + } + e || (this.previousCommand = null, e = {}), this.$opResetTimer.schedule(), this.curOp = { + command: e.command || {}, + args: e.args, + scrollTop: this.renderer.scrollTop + }, this.curOp.command.name && this.curOp.command.scrollIntoView !== undefined && this.$blockScrolling++ + }, this.endOperation = function(e) { + if (this.curOp) { + if (e && e.returnValue === !1) return this.curOp = null; + this._signal("beforeEndOperation"); + var t = this.curOp.command; + t.name && this.$blockScrolling > 0 && this.$blockScrolling--; + var n = t && t.scrollIntoView; + if (n) { + switch (n) { + case "center-animate": + n = "animate"; + case "center": + this.renderer.scrollCursorIntoView(null, .5); + break; + case "animate": + case "cursor": + this.renderer.scrollCursorIntoView(); + break; + case "selectionPart": + var r = this.selection.getRange(), + i = this.renderer.layerConfig; + (r.start.row >= i.lastRow || r.end.row <= i.firstRow) && this.renderer.scrollSelectionIntoView(this.selection.anchor, this.selection.lead); + break; + default: + } + n == "animate" && this.renderer.animateScrolling(this.curOp.scrollTop) + } + this.prevOp = this.curOp, this.curOp = null + } + }, this.$mergeableCommands = ["backspace", "del", "insertstring"], this.$historyTracker = function(e) { + if (!this.$mergeUndoDeltas) return; + var t = this.prevOp, + n = this.$mergeableCommands, + r = t.command && e.command.name == t.command.name; + if (e.command.name == "insertstring") { + var i = e.args; + this.mergeNextCommand === undefined && (this.mergeNextCommand = !0), r = r && this.mergeNextCommand && (!/\s/.test(i) || /\s/.test(t.args)), this.mergeNextCommand = !0 + } else r = r && n.indexOf(e.command.name) !== -1; + this.$mergeUndoDeltas != "always" && Date.now() - this.sequenceStartTime > 2e3 && (r = !1), r ? this.session.mergeUndoDeltas = !0 : n.indexOf(e.command.name) !== -1 && (this.sequenceStartTime = Date.now()) + }, this.setKeyboardHandler = function(e, t) { + if (e && typeof e == "string") { + this.$keybindingId = e; + var n = this; + g.loadModule(["keybinding", e], function(r) { + n.$keybindingId == e && n.keyBinding.setKeyboardHandler(r && r.handler), t && t() + }) + } else this.$keybindingId = null, this.keyBinding.setKeyboardHandler(e), t && t() + }, this.getKeyboardHandler = function() { + return this.keyBinding.getKeyboardHandler() + }, this.setSession = function(e) { + if (this.session == e) return; + this.curOp && this.endOperation(), this.curOp = {}; + var t = this.session; + if (t) { + this.session.off("change", this.$onDocumentChange), this.session.off("changeMode", this.$onChangeMode), this.session.off("tokenizerUpdate", this.$onTokenizerUpdate), this.session.off("changeTabSize", this.$onChangeTabSize), this.session.off("changeWrapLimit", this.$onChangeWrapLimit), this.session.off("changeWrapMode", this.$onChangeWrapMode), this.session.off("changeFold", this.$onChangeFold), this.session.off("changeFrontMarker", this.$onChangeFrontMarker), this.session.off("changeBackMarker", this.$onChangeBackMarker), this.session.off("changeBreakpoint", this.$onChangeBreakpoint), this.session.off("changeAnnotation", this.$onChangeAnnotation), this.session.off("changeOverwrite", this.$onCursorChange), this.session.off("changeScrollTop", this.$onScrollTopChange), this.session.off("changeScrollLeft", this.$onScrollLeftChange); + var n = this.session.getSelection(); + n.off("changeCursor", this.$onCursorChange), n.off("changeSelection", this.$onSelectionChange) + } + this.session = e, e ? (this.$onDocumentChange = this.onDocumentChange.bind(this), e.on("change", this.$onDocumentChange), this.renderer.setSession(e), this.$onChangeMode = this.onChangeMode.bind(this), e.on("changeMode", this.$onChangeMode), this.$onTokenizerUpdate = this.onTokenizerUpdate.bind(this), e.on("tokenizerUpdate", this.$onTokenizerUpdate), this.$onChangeTabSize = this.renderer.onChangeTabSize.bind(this.renderer), e.on("changeTabSize", this.$onChangeTabSize), this.$onChangeWrapLimit = this.onChangeWrapLimit.bind(this), e.on("changeWrapLimit", this.$onChangeWrapLimit), this.$onChangeWrapMode = this.onChangeWrapMode.bind(this), e.on("changeWrapMode", this.$onChangeWrapMode), this.$onChangeFold = this.onChangeFold.bind(this), e.on("changeFold", this.$onChangeFold), this.$onChangeFrontMarker = this.onChangeFrontMarker.bind(this), this.session.on("changeFrontMarker", this.$onChangeFrontMarker), this.$onChangeBackMarker = this.onChangeBackMarker.bind(this), this.session.on("changeBackMarker", this.$onChangeBackMarker), this.$onChangeBreakpoint = this.onChangeBreakpoint.bind(this), this.session.on("changeBreakpoint", this.$onChangeBreakpoint), this.$onChangeAnnotation = this.onChangeAnnotation.bind(this), this.session.on("changeAnnotation", this.$onChangeAnnotation), this.$onCursorChange = this.onCursorChange.bind(this), this.session.on("changeOverwrite", this.$onCursorChange), this.$onScrollTopChange = this.onScrollTopChange.bind(this), this.session.on("changeScrollTop", this.$onScrollTopChange), this.$onScrollLeftChange = this.onScrollLeftChange.bind(this), this.session.on("changeScrollLeft", this.$onScrollLeftChange), this.selection = e.getSelection(), this.selection.on("changeCursor", this.$onCursorChange), this.$onSelectionChange = this.onSelectionChange.bind(this), this.selection.on("changeSelection", this.$onSelectionChange), this.onChangeMode(), this.$blockScrolling += 1, this.onCursorChange(), this.$blockScrolling -= 1, this.onScrollTopChange(), this.onScrollLeftChange(), this.onSelectionChange(), this.onChangeFrontMarker(), this.onChangeBackMarker(), this.onChangeBreakpoint(), this.onChangeAnnotation(), this.session.getUseWrapMode() && this.renderer.adjustWrapLimit(), this.renderer.updateFull()) : (this.selection = null, this.renderer.setSession(e)), this._signal("changeSession", { + session: e, + oldSession: t + }), this.curOp = null, t && t._signal("changeEditor", { + oldEditor: this + }), e && e._signal("changeEditor", { + editor: this + }), e && e.bgTokenizer && e.bgTokenizer.scheduleStart() + }, this.getSession = function() { + return this.session + }, this.setValue = function(e, t) { + return this.session.doc.setValue(e), t ? t == 1 ? this.navigateFileEnd() : t == -1 && this.navigateFileStart() : this.selectAll(), e + }, this.getValue = function() { + return this.session.getValue() + }, this.getSelection = function() { + return this.selection + }, this.resize = function(e) { + this.renderer.onResize(e) + }, this.setTheme = function(e, t) { + this.renderer.setTheme(e, t) + }, this.getTheme = function() { + return this.renderer.getTheme() + }, this.setStyle = function(e) { + this.renderer.setStyle(e) + }, this.unsetStyle = function(e) { + this.renderer.unsetStyle(e) + }, this.getFontSize = function() { + return this.getOption("fontSize") || i.computedStyle(this.container, "fontSize") + }, this.setFontSize = function(e) { + this.setOption("fontSize", e) + }, this.$highlightBrackets = function() { + this.session.$bracketHighlight && (this.session.removeMarker(this.session.$bracketHighlight), this.session.$bracketHighlight = null); + if (this.$highlightPending) return; + var e = this; + this.$highlightPending = !0, setTimeout(function() { + e.$highlightPending = !1; + var t = e.session; + if (!t || !t.bgTokenizer) return; + var n = t.findMatchingBracket(e.getCursorPosition()); + if (n) var r = new p(n.row, n.column, n.row, n.column + 1); + else if (t.$mode.getMatching) var r = t.$mode.getMatching(e.session); + r && (t.$bracketHighlight = t.addMarker(r, "ace_bracket", "text")) + }, 50) + }, this.$highlightTags = function() { + if (this.$highlightTagPending) return; + var e = this; + this.$highlightTagPending = !0, setTimeout(function() { + e.$highlightTagPending = !1; + var t = e.session; + if (!t || !t.bgTokenizer) return; + var n = e.getCursorPosition(), + r = new y(e.session, n.row, n.column), + i = r.getCurrentToken(); + if (!i || !/\b(?:tag-open|tag-name)/.test(i.type)) { + t.removeMarker(t.$tagHighlight), t.$tagHighlight = null; + return + } + if (i.type.indexOf("tag-open") != -1) { + i = r.stepForward(); + if (!i) return + } + var s = i.value, + o = 0, + u = r.stepBackward(); + if (u.value == "<") { + do u = i, i = r.stepForward(), i && i.value === s && i.type.indexOf("tag-name") !== -1 && (u.value === "<" ? o++ : u.value === "= 0) + } else { + do i = u, u = r.stepBackward(), i && i.value === s && i.type.indexOf("tag-name") !== -1 && (u.value === "<" ? o++ : u.value === " 1) && (t = !1) + } + if (e.$highlightLineMarker && !t) e.removeMarker(e.$highlightLineMarker.id), e.$highlightLineMarker = null; + else if (!e.$highlightLineMarker && t) { + var n = new p(t.row, t.column, t.row, Infinity); + n.id = e.addMarker(n, "ace_active-line", "screenLine"), e.$highlightLineMarker = n + } else t && (e.$highlightLineMarker.start.row = t.row, e.$highlightLineMarker.end.row = t.row, e.$highlightLineMarker.start.column = t.column, e._signal("changeBackMarker")) + }, this.onSelectionChange = function(e) { + var t = this.session; + t.$selectionMarker && t.removeMarker(t.$selectionMarker), t.$selectionMarker = null; + if (!this.selection.isEmpty()) { + var n = this.selection.getRange(), + r = this.getSelectionStyle(); + t.$selectionMarker = t.addMarker(n, "ace_selection", r) + } else this.$updateHighlightActiveLine(); + var i = this.$highlightSelectedWord && this.$getSelectionHighLightRegexp(); + this.session.highlight(i), this._signal("changeSelection") + }, this.$getSelectionHighLightRegexp = function() { + var e = this.session, + t = this.getSelectionRange(); + if (t.isEmpty() || t.isMultiLine()) return; + var n = t.start.column - 1, + r = t.end.column + 1, + i = e.getLine(t.start.row), + s = i.length, + o = i.substring(Math.max(n, 0), Math.min(r, s)); + if (n >= 0 && /^[\w\d]/.test(o) || r <= s && /[\w\d]$/.test(o)) return; + o = i.substring(t.start.column, t.end.column); + if (!/^[\w\d]+$/.test(o)) return; + var u = this.$search.$assembleRegExp({ + wholeWord: !0, + caseSensitive: !0, + needle: o + }); + return u + }, this.onChangeFrontMarker = function() { + this.renderer.updateFrontMarkers() + }, this.onChangeBackMarker = function() { + this.renderer.updateBackMarkers() + }, this.onChangeBreakpoint = function() { + this.renderer.updateBreakpoints() + }, this.onChangeAnnotation = function() { + this.renderer.setAnnotations(this.session.getAnnotations()) + }, this.onChangeMode = function(e) { + this.renderer.updateText(), this._emit("changeMode", e) + }, this.onChangeWrapLimit = function() { + this.renderer.updateFull() + }, this.onChangeWrapMode = function() { + this.renderer.onResize(!0) + }, this.onChangeFold = function() { + this.$updateHighlightActiveLine(), this.renderer.updateFull() + }, this.getSelectedText = function() { + return this.session.getTextRange(this.getSelectionRange()) + }, this.getCopyText = function() { + var e = this.getSelectedText(); + return this._signal("copy", e), e + }, this.onCopy = function() { + this.commands.exec("copy", this) + }, this.onCut = function() { + this.commands.exec("cut", this) + }, this.onPaste = function(e, t) { + var n = { + text: e, + event: t + }; + this.commands.exec("paste", this, n) + }, this.$handlePaste = function(e) { + typeof e == "string" && (e = { + text: e + }), this._signal("paste", e); + var t = e.text; + if (!this.inMultiSelectMode || this.inVirtualSelectionMode) this.insert(t); + else { + var n = t.split(/\r\n|\r|\n/), + r = this.selection.rangeList.ranges; + if (n.length > r.length || n.length < 2 || !n[1]) return this.commands.exec("insertstring", this, t); + for (var i = r.length; i--;) { + var s = r[i]; + s.isEmpty() || this.session.remove(s), this.session.insert(s.start, n[i]) + } + } + }, this.execCommand = function(e, t) { + return this.commands.exec(e, this, t) + }, this.insert = function(e, t) { + var n = this.session, + r = n.getMode(), + i = this.getCursorPosition(); + if (this.getBehavioursEnabled() && !t) { + var s = r.transformAction(n.getState(i.row), "insertion", this, n, e); + s && (e !== s.text && (this.session.mergeUndoDeltas = !1, this.$mergeNextCommand = !1), e = s.text) + } + e == " " && (e = this.session.getTabString()); + if (!this.selection.isEmpty()) { + var o = this.getSelectionRange(); + i = this.session.remove(o), this.clearSelection() + } else if (this.session.getOverwrite() && e.indexOf("\n") == -1) { + var o = new p.fromPoints(i, i); + o.end.column += e.length, this.session.remove(o) + } + if (e == "\n" || e == "\r\n") { + var u = n.getLine(i.row); + if (i.column > u.search(/\S|$/)) { + var a = u.substr(i.column).search(/\S|$/); + n.doc.removeInLine(i.row, i.column, i.column + a) + } + } + this.clearSelection(); + var f = i.column, + l = n.getState(i.row), + u = n.getLine(i.row), + c = r.checkOutdent(l, u, e), + h = n.insert(i, e); + s && s.selection && (s.selection.length == 2 ? this.selection.setSelectionRange(new p(i.row, f + s.selection[0], i.row, f + s.selection[1])) : this.selection.setSelectionRange(new p(i.row + s.selection[0], s.selection[1], i.row + s.selection[2], s.selection[3]))); + if (n.getDocument().isNewLine(e)) { + var d = r.getNextLineIndent(l, u.slice(0, i.column), n.getTabString()); + n.insert({ + row: i.row + 1, + column: 0 + }, d) + } + c && r.autoOutdent(l, n, i.row) + }, this.onTextInput = function(e) { + this.keyBinding.onTextInput(e) + }, this.onCommandKey = function(e, t, n) { + this.keyBinding.onCommandKey(e, t, n) + }, this.setOverwrite = function(e) { + this.session.setOverwrite(e) + }, this.getOverwrite = function() { + return this.session.getOverwrite() + }, this.toggleOverwrite = function() { + this.session.toggleOverwrite() + }, this.setScrollSpeed = function(e) { + this.setOption("scrollSpeed", e) + }, this.getScrollSpeed = function() { + return this.getOption("scrollSpeed") + }, this.setDragDelay = function(e) { + this.setOption("dragDelay", e) + }, this.getDragDelay = function() { + return this.getOption("dragDelay") + }, this.setSelectionStyle = function(e) { + this.setOption("selectionStyle", e) + }, this.getSelectionStyle = function() { + return this.getOption("selectionStyle") + }, this.setHighlightActiveLine = function(e) { + this.setOption("highlightActiveLine", e) + }, this.getHighlightActiveLine = function() { + return this.getOption("highlightActiveLine") + }, this.setHighlightGutterLine = function(e) { + this.setOption("highlightGutterLine", e) + }, this.getHighlightGutterLine = function() { + return this.getOption("highlightGutterLine") + }, this.setHighlightSelectedWord = function(e) { + this.setOption("highlightSelectedWord", e) + }, this.getHighlightSelectedWord = function() { + return this.$highlightSelectedWord + }, this.setAnimatedScroll = function(e) { + this.renderer.setAnimatedScroll(e) + }, this.getAnimatedScroll = function() { + return this.renderer.getAnimatedScroll() + }, this.setShowInvisibles = function(e) { + this.renderer.setShowInvisibles(e) + }, this.getShowInvisibles = function() { + return this.renderer.getShowInvisibles() + }, this.setDisplayIndentGuides = function(e) { + this.renderer.setDisplayIndentGuides(e) + }, this.getDisplayIndentGuides = function() { + return this.renderer.getDisplayIndentGuides() + }, this.setShowPrintMargin = function(e) { + this.renderer.setShowPrintMargin(e) + }, this.getShowPrintMargin = function() { + return this.renderer.getShowPrintMargin() + }, this.setPrintMarginColumn = function(e) { + this.renderer.setPrintMarginColumn(e) + }, this.getPrintMarginColumn = function() { + return this.renderer.getPrintMarginColumn() + }, this.setReadOnly = function(e) { + this.setOption("readOnly", e) + }, this.getReadOnly = function() { + return this.getOption("readOnly") + }, this.setBehavioursEnabled = function(e) { + this.setOption("behavioursEnabled", e) + }, this.getBehavioursEnabled = function() { + return this.getOption("behavioursEnabled") + }, this.setWrapBehavioursEnabled = function(e) { + this.setOption("wrapBehavioursEnabled", e) + }, this.getWrapBehavioursEnabled = function() { + return this.getOption("wrapBehavioursEnabled") + }, this.setShowFoldWidgets = function(e) { + this.setOption("showFoldWidgets", e) + }, this.getShowFoldWidgets = function() { + return this.getOption("showFoldWidgets") + }, this.setFadeFoldWidgets = function(e) { + this.setOption("fadeFoldWidgets", e) + }, this.getFadeFoldWidgets = function() { + return this.getOption("fadeFoldWidgets") + }, this.remove = function(e) { + this.selection.isEmpty() && (e == "left" ? this.selection.selectLeft() : this.selection.selectRight()); + var t = this.getSelectionRange(); + if (this.getBehavioursEnabled()) { + var n = this.session, + r = n.getState(t.start.row), + i = n.getMode().transformAction(r, "deletion", this, n, t); + if (t.end.column === 0) { + var s = n.getTextRange(t); + if (s[s.length - 1] == "\n") { + var o = n.getLine(t.end.row); + /^\s+$/.test(o) && (t.end.column = o.length) + } + } + i && (t = i) + } + this.session.remove(t), this.clearSelection() + }, this.removeWordRight = function() { + this.selection.isEmpty() && this.selection.selectWordRight(), this.session.remove(this.getSelectionRange()), this.clearSelection() + }, this.removeWordLeft = function() { + this.selection.isEmpty() && this.selection.selectWordLeft(), this.session.remove(this.getSelectionRange()), this.clearSelection() + }, this.removeToLineStart = function() { + this.selection.isEmpty() && this.selection.selectLineStart(), this.session.remove(this.getSelectionRange()), this.clearSelection() + }, this.removeToLineEnd = function() { + this.selection.isEmpty() && this.selection.selectLineEnd(); + var e = this.getSelectionRange(); + e.start.column == e.end.column && e.start.row == e.end.row && (e.end.column = 0, e.end.row++), this.session.remove(e), this.clearSelection() + }, this.splitLine = function() { + this.selection.isEmpty() || (this.session.remove(this.getSelectionRange()), this.clearSelection()); + var e = this.getCursorPosition(); + this.insert("\n"), this.moveCursorToPosition(e) + }, this.transposeLetters = function() { + if (!this.selection.isEmpty()) return; + var e = this.getCursorPosition(), + t = e.column; + if (t === 0) return; + var n = this.session.getLine(e.row), + r, i; + t < n.length ? (r = n.charAt(t) + n.charAt(t - 1), i = new p(e.row, t - 1, e.row, t + 1)) : (r = n.charAt(t - 1) + n.charAt(t - 2), i = new p(e.row, t - 2, e.row, t)), this.session.replace(i, r), this.session.selection.moveToPosition(i.end) + }, this.toLowerCase = function() { + var e = this.getSelectionRange(); + this.selection.isEmpty() && this.selection.selectWord(); + var t = this.getSelectionRange(), + n = this.session.getTextRange(t); + this.session.replace(t, n.toLowerCase()), this.selection.setSelectionRange(e) + }, this.toUpperCase = function() { + var e = this.getSelectionRange(); + this.selection.isEmpty() && this.selection.selectWord(); + var t = this.getSelectionRange(), + n = this.session.getTextRange(t); + this.session.replace(t, n.toUpperCase()), this.selection.setSelectionRange(e) + }, this.indent = function() { + var e = this.session, + t = this.getSelectionRange(); + if (t.start.row < t.end.row) { + var n = this.$getSelectedRows(); + e.indentRows(n.first, n.last, " "); + return + } + if (t.start.column < t.end.column) { + var r = e.getTextRange(t); + if (!/^\s+$/.test(r)) { + var n = this.$getSelectedRows(); + e.indentRows(n.first, n.last, " "); + return + } + } + var i = e.getLine(t.start.row), + o = t.start, + u = e.getTabSize(), + a = e.documentToScreenColumn(o.row, o.column); + if (this.session.getUseSoftTabs()) var f = u - a % u, + l = s.stringRepeat(" ", f); + else { + var f = a % u; + while (i[t.start.column - 1] == " " && f) t.start.column--, f--; + this.selection.setSelectionRange(t), l = " " + } + return this.insert(l) + }, this.blockIndent = function() { + var e = this.$getSelectedRows(); + this.session.indentRows(e.first, e.last, " ") + }, this.blockOutdent = function() { + var e = this.session.getSelection(); + this.session.outdentRows(e.getRange()) + }, this.sortLines = function() { + var e = this.$getSelectedRows(), + t = this.session, + n = []; + for (var r = e.first; r <= e.last; r++) n.push(t.getLine(r)); + n.sort(function(e, t) { + return e.toLowerCase() < t.toLowerCase() ? -1 : e.toLowerCase() > t.toLowerCase() ? 1 : 0 + }); + var i = new p(0, 0, 0, 0); + for (var r = e.first; r <= e.last; r++) { + var s = t.getLine(r); + i.start.row = r, i.end.row = r, i.end.column = s.length, t.replace(i, n[r - e.first]) + } + }, this.toggleCommentLines = function() { + var e = this.session.getState(this.getCursorPosition().row), + t = this.$getSelectedRows(); + this.session.getMode().toggleCommentLines(e, this.session, t.first, t.last) + }, this.toggleBlockComment = function() { + var e = this.getCursorPosition(), + t = this.session.getState(e.row), + n = this.getSelectionRange(); + this.session.getMode().toggleBlockComment(t, this.session, n, e) + }, this.getNumberAt = function(e, t) { + var n = /[\-]?[0-9]+(?:\.[0-9]+)?/g; + n.lastIndex = 0; + var r = this.session.getLine(e); + while (n.lastIndex < t) { + var i = n.exec(r); + if (i.index <= t && i.index + i[0].length >= t) { + var s = { + value: i[0], + start: i.index, + end: i.index + i[0].length + }; + return s + } + } + return null + }, this.modifyNumber = function(e) { + var t = this.selection.getCursor().row, + n = this.selection.getCursor().column, + r = new p(t, n - 1, t, n), + i = this.session.getTextRange(r); + if (!isNaN(parseFloat(i)) && isFinite(i)) { + var s = this.getNumberAt(t, n); + if (s) { + var o = s.value.indexOf(".") >= 0 ? s.start + s.value.indexOf(".") + 1 : s.end, + u = s.start + s.value.length - o, + a = parseFloat(s.value); + a *= Math.pow(10, u), o !== s.end && n < o ? e *= Math.pow(10, s.end - n - 1) : e *= Math.pow(10, s.end - n), a += e, a /= Math.pow(10, u); + var f = a.toFixed(u), + l = new p(t, s.start, t, s.end); + this.session.replace(l, f), this.moveCursorTo(t, Math.max(s.start + 1, n + f.length - s.value.length)) + } + } + }, this.removeLines = function() { + var e = this.$getSelectedRows(); + this.session.removeFullLines(e.first, e.last), this.clearSelection() + }, this.duplicateSelection = function() { + var e = this.selection, + t = this.session, + n = e.getRange(), + r = e.isBackwards(); + if (n.isEmpty()) { + var i = n.start.row; + t.duplicateLines(i, i) + } else { + var s = r ? n.start : n.end, + o = t.insert(s, t.getTextRange(n), !1); + n.start = s, n.end = o, e.setSelectionRange(n, r) + } + }, this.moveLinesDown = function() { + this.$moveLines(1, !1) + }, this.moveLinesUp = function() { + this.$moveLines(-1, !1) + }, this.moveText = function(e, t, n) { + return this.session.moveText(e, t, n) + }, this.copyLinesUp = function() { + this.$moveLines(-1, !0) + }, this.copyLinesDown = function() { + this.$moveLines(1, !0) + }, this.$moveLines = function(e, t) { + var n, r, i = this.selection; + if (!i.inMultiSelectMode || this.inVirtualSelectionMode) { + var s = i.toOrientedRange(); + n = this.$getSelectedRows(s), r = this.session.$moveLines(n.first, n.last, t ? 0 : e), t && e == -1 && (r = 0), s.moveBy(r, 0), i.fromOrientedRange(s) + } else { + var o = i.rangeList.ranges; + i.rangeList.detach(this.session), this.inVirtualSelectionMode = !0; + var u = 0, + a = 0, + f = o.length; + for (var l = 0; l < f; l++) { + var c = l; + o[l].moveBy(u, 0), n = this.$getSelectedRows(o[l]); + var h = n.first, + p = n.last; + while (++l < f) { + a && o[l].moveBy(a, 0); + var d = this.$getSelectedRows(o[l]); + if (t && d.first != p) break; + if (!t && d.first > p + 1) break; + p = d.last + } + l--, u = this.session.$moveLines(h, p, t ? 0 : e), t && e == -1 && (c = l + 1); + while (c <= l) o[c].moveBy(u, 0), c++; + t || (u = 0), a += u + } + i.fromOrientedRange(i.ranges[0]), i.rangeList.attach(this.session), this.inVirtualSelectionMode = !1 + } + }, this.$getSelectedRows = function(e) { + return e = (e || this.getSelectionRange()).collapseRows(), { + first: this.session.getRowFoldStart(e.start.row), + last: this.session.getRowFoldEnd(e.end.row) + } + }, this.onCompositionStart = function(e) { + this.renderer.showComposition(this.getCursorPosition()) + }, this.onCompositionUpdate = function(e) { + this.renderer.setCompositionText(e) + }, this.onCompositionEnd = function() { + this.renderer.hideComposition() + }, this.getFirstVisibleRow = function() { + return this.renderer.getFirstVisibleRow() + }, this.getLastVisibleRow = function() { + return this.renderer.getLastVisibleRow() + }, this.isRowVisible = function(e) { + return e >= this.getFirstVisibleRow() && e <= this.getLastVisibleRow() + }, this.isRowFullyVisible = function(e) { + return e >= this.renderer.getFirstFullyVisibleRow() && e <= this.renderer.getLastFullyVisibleRow() + }, this.$getVisibleRowCount = function() { + return this.renderer.getScrollBottomRow() - this.renderer.getScrollTopRow() + 1 + }, this.$moveByPage = function(e, t) { + var n = this.renderer, + r = this.renderer.layerConfig, + i = e * Math.floor(r.height / r.lineHeight); + this.$blockScrolling++, t === !0 ? this.selection.$moveSelection(function() { + this.moveCursorBy(i, 0) + }) : t === !1 && (this.selection.moveCursorBy(i, 0), this.selection.clearSelection()), this.$blockScrolling--; + var s = n.scrollTop; + n.scrollBy(0, i * r.lineHeight), t != null && n.scrollCursorIntoView(null, .5), n.animateScrolling(s) + }, this.selectPageDown = function() { + this.$moveByPage(1, !0) + }, this.selectPageUp = function() { + this.$moveByPage(-1, !0) + }, this.gotoPageDown = function() { + this.$moveByPage(1, !1) + }, this.gotoPageUp = function() { + this.$moveByPage(-1, !1) + }, this.scrollPageDown = function() { + this.$moveByPage(1) + }, this.scrollPageUp = function() { + this.$moveByPage(-1) + }, this.scrollToRow = function(e) { + this.renderer.scrollToRow(e) + }, this.scrollToLine = function(e, t, n, r) { + this.renderer.scrollToLine(e, t, n, r) + }, this.centerSelection = function() { + var e = this.getSelectionRange(), + t = { + row: Math.floor(e.start.row + (e.end.row - e.start.row) / 2), + column: Math.floor(e.start.column + (e.end.column - e.start.column) / 2) + }; + this.renderer.alignCursor(t, .5) + }, this.getCursorPosition = function() { + return this.selection.getCursor() + }, this.getCursorPositionScreen = function() { + return this.session.documentToScreenPosition(this.getCursorPosition()) + }, this.getSelectionRange = function() { + return this.selection.getRange() + }, this.selectAll = function() { + this.$blockScrolling += 1, this.selection.selectAll(), this.$blockScrolling -= 1 + }, this.clearSelection = function() { + this.selection.clearSelection() + }, this.moveCursorTo = function(e, t) { + this.selection.moveCursorTo(e, t) + }, this.moveCursorToPosition = function(e) { + this.selection.moveCursorToPosition(e) + }, this.jumpToMatching = function(e, t) { + var n = this.getCursorPosition(), + r = new y(this.session, n.row, n.column), + i = r.getCurrentToken(), + s = i || r.stepForward(); + if (!s) return; + var o, u = !1, + a = {}, + f = n.column - s.start, + l, c = { + ")": "(", + "(": "(", + "]": "[", + "[": "[", + "{": "{", + "}": "{" + }; + do { + if (s.value.match(/[{}()\[\]]/g)) + for (; f < s.value.length && !u; f++) { + if (!c[s.value[f]]) continue; + l = c[s.value[f]] + "." + s.type.replace("rparen", "lparen"), isNaN(a[l]) && (a[l] = 0); + switch (s.value[f]) { + case "(": + case "[": + case "{": + a[l]++; + break; + case ")": + case "]": + case "}": + a[l]--, a[l] === -1 && (o = "bracket", u = !0) + } + } else s && s.type.indexOf("tag-name") !== -1 && (isNaN(a[s.value]) && (a[s.value] = 0), i.value === "<" ? a[s.value]++ : i.value === "= 0; --s) this.$tryReplace(n[s], e) && r++; + return this.selection.setSelectionRange(i), this.$blockScrolling -= 1, r + }, this.$tryReplace = function(e, t) { + var n = this.session.getTextRange(e); + return t = this.$search.replace(n, t), t !== null ? (e.end = this.session.replace(e, t), e) : null + }, this.getLastSearchOptions = function() { + return this.$search.getOptions() + }, this.find = function(e, t, n) { + t || (t = {}), typeof e == "string" || e instanceof RegExp ? t.needle = e : typeof e == "object" && r.mixin(t, e); + var i = this.selection.getRange(); + t.needle == null && (e = this.session.getTextRange(i) || this.$search.$options.needle, e || (i = this.session.getWordRange(i.start.row, i.start.column), e = this.session.getTextRange(i)), this.$search.set({ + needle: e + })), this.$search.set(t), t.start || this.$search.set({ + start: i + }); + var s = this.$search.find(this.session); + if (t.preventScroll) return s; + if (s) return this.revealRange(s, n), s; + t.backwards ? i.start = i.end : i.end = i.start, this.selection.setRange(i) + }, this.findNext = function(e, t) { + this.find({ + skipCurrent: !0, + backwards: !1 + }, e, t) + }, this.findPrevious = function(e, t) { + this.find(e, { + skipCurrent: !0, + backwards: !0 + }, t) + }, this.revealRange = function(e, t) { + this.$blockScrolling += 1, this.session.unfold(e), this.selection.setSelectionRange(e), this.$blockScrolling -= 1; + var n = this.renderer.scrollTop; + this.renderer.scrollSelectionIntoView(e.start, e.end, .5), t !== !1 && this.renderer.animateScrolling(n) + }, this.undo = function() { + this.$blockScrolling++, this.session.getUndoManager().undo(), this.$blockScrolling--, this.renderer.scrollCursorIntoView(null, .5) + }, this.redo = function() { + this.$blockScrolling++, this.session.getUndoManager().redo(), this.$blockScrolling--, this.renderer.scrollCursorIntoView(null, .5) + }, this.destroy = function() { + this.renderer.destroy(), this._signal("destroy", this), this.session && this.session.destroy() + }, this.setAutoScrollEditorIntoView = function(e) { + if (!e) return; + var t, n = this, + r = !1; + this.$scrollAnchor || (this.$scrollAnchor = document.createElement("div")); + var i = this.$scrollAnchor; + i.style.cssText = "position:absolute", this.container.insertBefore(i, this.container.firstChild); + var s = this.on("changeSelection", function() { + r = !0 + }), + o = this.renderer.on("beforeRender", function() { + r && (t = n.renderer.container.getBoundingClientRect()) + }), + u = this.renderer.on("afterRender", function() { + if (r && t && (n.isFocused() || n.searchBox && n.searchBox.isFocused())) { + var e = n.renderer, + s = e.$cursorLayer.$pixelPos, + o = e.layerConfig, + u = s.top - o.offset; + s.top >= 0 && u + t.top < 0 ? r = !0 : s.top < o.height && s.top + t.top + o.lineHeight > window.innerHeight ? r = !1 : r = null, r != null && (i.style.top = u + "px", i.style.left = s.left + "px", i.style.height = o.lineHeight + "px", i.scrollIntoView(r)), r = t = null + } + }); + this.setAutoScrollEditorIntoView = function(e) { + if (e) return; + delete this.setAutoScrollEditorIntoView, this.off("changeSelection", s), this.renderer.off("afterRender", u), this.renderer.off("beforeRender", o) + } + }, this.$resetCursorStyle = function() { + var e = this.$cursorStyle || "ace", + t = this.renderer.$cursorLayer; + if (!t) return; + t.setSmoothBlinking(/smooth/.test(e)), t.isBlinking = !this.$readOnly && e != "wide", i.setCssClass(t.element, "ace_slim-cursors", /slim/.test(e)) + } + }.call(b.prototype), g.defineOptions(b.prototype, "editor", { + selectionStyle: { + set: function(e) { + this.onSelectionChange(), this._signal("changeSelectionStyle", { + data: e + }) + }, + initialValue: "line" + }, + highlightActiveLine: { + set: function() { + this.$updateHighlightActiveLine() + }, + initialValue: !0 + }, + highlightSelectedWord: { + set: function(e) { + this.$onSelectionChange() + }, + initialValue: !0 + }, + readOnly: { + set: function(e) { + this.$resetCursorStyle() + }, + initialValue: !1 + }, + cursorStyle: { + set: function(e) { + this.$resetCursorStyle() + }, + values: ["ace", "slim", "smooth", "wide"], + initialValue: "ace" + }, + mergeUndoDeltas: { + values: [!1, !0, "always"], + initialValue: !0 + }, + behavioursEnabled: { + initialValue: !0 + }, + wrapBehavioursEnabled: { + initialValue: !0 + }, + autoScrollEditorIntoView: { + set: function(e) { + this.setAutoScrollEditorIntoView(e) + } + }, + keyboardHandler: { + set: function(e) { + this.setKeyboardHandler(e) + }, + get: function() { + return this.keybindingId + }, + handlesSet: !0 + }, + hScrollBarAlwaysVisible: "renderer", + vScrollBarAlwaysVisible: "renderer", + highlightGutterLine: "renderer", + animatedScroll: "renderer", + showInvisibles: "renderer", + showPrintMargin: "renderer", + printMarginColumn: "renderer", + printMargin: "renderer", + fadeFoldWidgets: "renderer", + showFoldWidgets: "renderer", + showLineNumbers: "renderer", + showGutter: "renderer", + displayIndentGuides: "renderer", + fontSize: "renderer", + fontFamily: "renderer", + maxLines: "renderer", + minLines: "renderer", + scrollPastEnd: "renderer", + fixedWidthGutter: "renderer", + theme: "renderer", + scrollSpeed: "$mouseHandler", + dragDelay: "$mouseHandler", + dragEnabled: "$mouseHandler", + focusTimout: "$mouseHandler", + tooltipFollowsMouse: "$mouseHandler", + firstLineNumber: "session", + overwrite: "session", + newLineMode: "session", + useWorker: "session", + useSoftTabs: "session", + tabSize: "session", + wrap: "session", + indentedSoftWrap: "session", + foldStyle: "session", + mode: "session" + }), t.Editor = b +}), define("ace/undomanager", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + var r = function() { + this.reset() + }; + (function() { + function e(e) { + return { + action: e.action, + start: e.start, + end: e.end, + lines: e.lines.length == 1 ? null : e.lines, + text: e.lines.length == 1 ? e.lines[0] : null + } + } + + function t(e) { + return { + action: e.action, + start: e.start, + end: e.end, + lines: e.lines || [e.text] + } + } + + function n(e, t) { + var n = new Array(e.length); + for (var r = 0; r < e.length; r++) { + var i = e[r], + s = { + group: i.group, + deltas: new Array(i.length) + }; + for (var o = 0; o < i.deltas.length; o++) { + var u = i.deltas[o]; + s.deltas[o] = t(u) + } + n[r] = s + } + return n + } + this.execute = function(e) { + var t = e.args[0]; + this.$doc = e.args[1], e.merge && this.hasUndo() && (this.dirtyCounter--, t = this.$undoStack.pop().concat(t)), this.$undoStack.push(t), this.$redoStack = [], this.dirtyCounter < 0 && (this.dirtyCounter = NaN), this.dirtyCounter++ + }, this.undo = function(e) { + var t = this.$undoStack.pop(), + n = null; + return t && (n = this.$doc.undoChanges(t, e), this.$redoStack.push(t), this.dirtyCounter--), n + }, this.redo = function(e) { + var t = this.$redoStack.pop(), + n = null; + return t && (n = this.$doc.redoChanges(this.$deserializeDeltas(t), e), this.$undoStack.push(t), this.dirtyCounter++), n + }, this.reset = function() { + this.$undoStack = [], this.$redoStack = [], this.dirtyCounter = 0 + }, this.hasUndo = function() { + return this.$undoStack.length > 0 + }, this.hasRedo = function() { + return this.$redoStack.length > 0 + }, this.markClean = function() { + this.dirtyCounter = 0 + }, this.isClean = function() { + return this.dirtyCounter === 0 + }, this.$serializeDeltas = function(t) { + return n(t, e) + }, this.$deserializeDeltas = function(e) { + return n(e, t) + } + }).call(r.prototype), t.UndoManager = r +}), define("ace/layer/gutter", ["require", "exports", "module", "ace/lib/dom", "ace/lib/oop", "ace/lib/lang", "ace/lib/event_emitter"], function(e, t, n) { + "use strict"; + var r = e("../lib/dom"), + i = e("../lib/oop"), + s = e("../lib/lang"), + o = e("../lib/event_emitter").EventEmitter, + u = function(e) { + this.element = r.createElement("div"), this.element.className = "ace_layer ace_gutter-layer", e.appendChild(this.element), this.setShowFoldWidgets(this.$showFoldWidgets), this.gutterWidth = 0, this.$annotations = [], this.$updateAnnotations = this.$updateAnnotations.bind(this), this.$cells = [] + }; + (function() { + i.implement(this, o), this.setSession = function(e) { + this.session && this.session.removeEventListener("change", this.$updateAnnotations), this.session = e, e && e.on("change", this.$updateAnnotations) + }, this.addGutterDecoration = function(e, t) { + window.console && console.warn && console.warn("deprecated use session.addGutterDecoration"), this.session.addGutterDecoration(e, t) + }, this.removeGutterDecoration = function(e, t) { + window.console && console.warn && console.warn("deprecated use session.removeGutterDecoration"), this.session.removeGutterDecoration(e, t) + }, this.setAnnotations = function(e) { + this.$annotations = []; + for (var t = 0; t < e.length; t++) { + var n = e[t], + r = n.row, + i = this.$annotations[r]; + i || (i = this.$annotations[r] = { + text: [] + }); + var o = n.text; + o = o ? s.escapeHTML(o) : n.html || "", i.text.indexOf(o) === -1 && i.text.push(o); + var u = n.type; + u == "error" ? i.className = " ace_error" : u == "warning" && i.className != " ace_error" ? i.className = " ace_warning" : u == "info" && !i.className && (i.className = " ace_info") + } + }, this.$updateAnnotations = function(e) { + if (!this.$annotations.length) return; + var t = e.start.row, + n = e.end.row - t; + if (n !== 0) + if (e.action == "remove") this.$annotations.splice(t, n + 1, null); + else { + var r = new Array(n + 1); + r.unshift(t, 1), this.$annotations.splice.apply(this.$annotations, r) + } + }, this.update = function(e) { + var t = this.session, + n = e.firstRow, + i = Math.min(e.lastRow + e.gutterOffset, t.getLength() - 1), + s = t.getNextFoldLine(n), + o = s ? s.start.row : Infinity, + u = this.$showFoldWidgets && t.foldWidgets, + a = t.$breakpoints, + f = t.$decorations, + l = t.$firstLineNumber, + c = 0, + h = t.gutterRenderer || this.$renderer, + p = null, + d = -1, + v = n; + for (;;) { + v > o && (v = s.end.row + 1, s = t.getNextFoldLine(v, s), o = s ? s.start.row : Infinity); + if (v > i) { + while (this.$cells.length > d + 1) p = this.$cells.pop(), this.element.removeChild(p.element); + break + } + p = this.$cells[++d], p || (p = { + element: null, + textNode: null, + foldWidget: null + }, p.element = r.createElement("div"), p.textNode = document.createTextNode(""), p.element.appendChild(p.textNode), this.element.appendChild(p.element), this.$cells[d] = p); + var m = "ace_gutter-cell "; + a[v] && (m += a[v]), f[v] && (m += f[v]), this.$annotations[v] && (m += this.$annotations[v].className), p.element.className != m && (p.element.className = m); + var g = t.getRowLength(v) * e.lineHeight + "px"; + g != p.element.style.height && (p.element.style.height = g); + if (u) { + var y = u[v]; + y == null && (y = u[v] = t.getFoldWidget(v)) + } + if (y) { + p.foldWidget || (p.foldWidget = r.createElement("span"), p.element.appendChild(p.foldWidget)); + var m = "ace_fold-widget ace_" + y; + y == "start" && v == o && v < s.end.row ? m += " ace_closed" : m += " ace_open", p.foldWidget.className != m && (p.foldWidget.className = m); + var g = e.lineHeight + "px"; + p.foldWidget.style.height != g && (p.foldWidget.style.height = g) + } else p.foldWidget && (p.element.removeChild(p.foldWidget), p.foldWidget = null); + var b = c = h ? h.getText(t, v) : v + l; + b !== p.textNode.data && (p.textNode.data = b), v++ + } + this.element.style.height = e.minHeight + "px"; + if (this.$fixedWidth || t.$useWrapMode) c = t.getLength() + l; + var w = h ? h.getWidth(t, c, e) : c.toString().length * e.characterWidth, + E = this.$padding || this.$computePadding(); + w += E.left + E.right, w !== this.gutterWidth && !isNaN(w) && (this.gutterWidth = w, this.element.style.width = Math.ceil(this.gutterWidth) + "px", this._emit("changeGutterWidth", w)) + }, this.$fixedWidth = !1, this.$showLineNumbers = !0, this.$renderer = "", this.setShowLineNumbers = function(e) { + this.$renderer = !e && { + getWidth: function() { + return "" + }, + getText: function() { + return "" + } + } + }, this.getShowLineNumbers = function() { + return this.$showLineNumbers + }, this.$showFoldWidgets = !0, this.setShowFoldWidgets = function(e) { + e ? r.addCssClass(this.element, "ace_folding-enabled") : r.removeCssClass(this.element, "ace_folding-enabled"), this.$showFoldWidgets = e, this.$padding = null + }, this.getShowFoldWidgets = function() { + return this.$showFoldWidgets + }, this.$computePadding = function() { + if (!this.element.firstChild) return { + left: 0, + right: 0 + }; + var e = r.computedStyle(this.element.firstChild); + return this.$padding = {}, this.$padding.left = parseInt(e.paddingLeft) + 1 || 0, this.$padding.right = parseInt(e.paddingRight) || 0, this.$padding + }, this.getRegion = function(e) { + var t = this.$padding || this.$computePadding(), + n = this.element.getBoundingClientRect(); + if (e.x < t.left + n.left) return "markers"; + if (this.$showFoldWidgets && e.x > n.right - t.right) return "foldWidgets" + } + }).call(u.prototype), t.Gutter = u +}), define("ace/layer/marker", ["require", "exports", "module", "ace/range", "ace/lib/dom"], function(e, t, n) { + "use strict"; + var r = e("../range").Range, + i = e("../lib/dom"), + s = function(e) { + this.element = i.createElement("div"), this.element.className = "ace_layer ace_marker-layer", e.appendChild(this.element) + }; + (function() { + function e(e, t, n, r) { + return (e ? 1 : 0) | (t ? 2 : 0) | (n ? 4 : 0) | (r ? 8 : 0) + } + this.$padding = 0, this.setPadding = function(e) { + this.$padding = e + }, this.setSession = function(e) { + this.session = e + }, this.setMarkers = function(e) { + this.markers = e + }, this.update = function(e) { + if (!e) return; + this.config = e; + var t = []; + for (var n in this.markers) { + var r = this.markers[n]; + if (!r.range) { + r.update(t, this, this.session, e); + continue + } + var i = r.range.clipRows(e.firstRow, e.lastRow); + if (i.isEmpty()) continue; + i = i.toScreenRange(this.session); + if (r.renderer) { + var s = this.$getTop(i.start.row, e), + o = this.$padding + (this.session.$bidiHandler.isBidiRow(i.start.row) ? this.session.$bidiHandler.getPosLeft(i.start.column) : i.start.column * e.characterWidth); + r.renderer(t, i, o, s, e) + } else r.type == "fullLine" ? this.drawFullLineMarker(t, i, r.clazz, e) : r.type == "screenLine" ? this.drawScreenLineMarker(t, i, r.clazz, e) : i.isMultiLine() ? r.type == "text" ? this.drawTextMarker(t, i, r.clazz, e) : this.drawMultiLineMarker(t, i, r.clazz, e) : this.session.$bidiHandler.isBidiRow(i.start.row) ? this.drawBidiSingleLineMarker(t, i, r.clazz + " ace_start" + " ace_br15", e) : this.drawSingleLineMarker(t, i, r.clazz + " ace_start" + " ace_br15", e) + } + this.element.innerHTML = t.join("") + }, this.$getTop = function(e, t) { + return (e - t.firstRowScreen) * t.lineHeight + }, this.drawTextMarker = function(t, n, i, s, o) { + var u = this.session, + a = n.start.row, + f = n.end.row, + l = a, + c = 0, + h = 0, + p = u.getScreenLastRowColumn(l), + d = null, + v = new r(l, n.start.column, l, h); + for (; l <= f; l++) v.start.row = v.end.row = l, v.start.column = l == a ? n.start.column : u.getRowWrapIndent(l), v.end.column = p, c = h, h = p, p = l + 1 < f ? u.getScreenLastRowColumn(l + 1) : l == f ? 0 : n.end.column, d = i + (l == a ? " ace_start" : "") + " ace_br" + e(l == a || l == a + 1 && n.start.column, c < h, h > p, l == f), this.session.$bidiHandler.isBidiRow(l) ? this.drawBidiSingleLineMarker(t, v, d, s, l == f ? 0 : 1, o) : this.drawSingleLineMarker(t, v, d, s, l == f ? 0 : 1, o) + }, this.drawMultiLineMarker = function(e, t, n, r, i) { + var s = this.$padding, + o, u, a; + i = i || ""; + if (this.session.$bidiHandler.isBidiRow(t.start.row)) { + var f = t.clone(); + f.end.row = f.start.row, f.end.column = this.session.getLine(f.start.row).length, this.drawBidiSingleLineMarker(e, f, n + " ace_br1 ace_start", r, null, i) + } else o = r.lineHeight, u = this.$getTop(t.start.row, r), a = s + t.start.column * r.characterWidth, e.push("
"); + if (this.session.$bidiHandler.isBidiRow(t.end.row)) { + var f = t.clone(); + f.start.row = f.end.row, f.start.column = 0, this.drawBidiSingleLineMarker(e, f, n + " ace_br12", r, null, i) + } else { + var l = t.end.column * r.characterWidth; + o = r.lineHeight, u = this.$getTop(t.end.row, r), e.push("
") + } + o = (t.end.row - t.start.row - 1) * r.lineHeight; + if (o <= 0) return; + u = this.$getTop(t.start.row + 1, r); + var c = (t.start.column ? 1 : 0) | (t.end.column ? 0 : 8); + e.push("
") + }, this.drawSingleLineMarker = function(e, t, n, r, i, s) { + var o = r.lineHeight, + u = (t.end.column + (i || 0) - t.start.column) * r.characterWidth, + a = this.$getTop(t.start.row, r), + f = this.$padding + t.start.column * r.characterWidth; + e.push("
") + }, this.drawBidiSingleLineMarker = function(e, t, n, r, i, s) { + var o = r.lineHeight, + u = this.$getTop(t.start.row, r), + a = this.$padding, + f = this.session.$bidiHandler.getSelections(t.start.column, t.end.column); + f.forEach(function(t) { + e.push("
") + }) + }, this.drawFullLineMarker = function(e, t, n, r, i) { + var s = this.$getTop(t.start.row, r), + o = r.lineHeight; + t.start.row != t.end.row && (o += this.$getTop(t.end.row, r) - s), e.push("
") + }, this.drawScreenLineMarker = function(e, t, n, r, i) { + var s = this.$getTop(t.start.row, r), + o = r.lineHeight; + e.push("
") + } + }).call(s.prototype), t.Marker = s +}), define("ace/layer/text", ["require", "exports", "module", "ace/lib/oop", "ace/lib/dom", "ace/lib/lang", "ace/lib/useragent", "ace/lib/event_emitter"], function(e, t, n) { + "use strict"; + var r = e("../lib/oop"), + i = e("../lib/dom"), + s = e("../lib/lang"), + o = e("../lib/useragent"), + u = e("../lib/event_emitter").EventEmitter, + a = function(e) { + this.element = i.createElement("div"), this.element.className = "ace_layer ace_text-layer", e.appendChild(this.element), this.$updateEolChar = this.$updateEolChar.bind(this) + }; + (function() { + r.implement(this, u), this.EOF_CHAR = "\u00b6", this.EOL_CHAR_LF = "\u00ac", this.EOL_CHAR_CRLF = "\u00a4", this.EOL_CHAR = this.EOL_CHAR_LF, this.TAB_CHAR = "\u2014", this.SPACE_CHAR = "\u00b7", this.$padding = 0, this.$updateEolChar = function() { + var e = this.session.doc.getNewLineCharacter() == "\n" ? this.EOL_CHAR_LF : this.EOL_CHAR_CRLF; + if (this.EOL_CHAR != e) return this.EOL_CHAR = e, !0 + }, this.setPadding = function(e) { + this.$padding = e, this.element.style.padding = "0 " + e + "px" + }, this.getLineHeight = function() { + return this.$fontMetrics.$characterSize.height || 0 + }, this.getCharacterWidth = function() { + return this.$fontMetrics.$characterSize.width || 0 + }, this.$setFontMetrics = function(e) { + this.$fontMetrics = e, this.$fontMetrics.on("changeCharacterSize", function(e) { + this._signal("changeCharacterSize", e) + }.bind(this)), this.$pollSizeChanges() + }, this.checkForSizeChanges = function() { + this.$fontMetrics.checkForSizeChanges() + }, this.$pollSizeChanges = function() { + return this.$pollSizeChangesTimer = this.$fontMetrics.$pollSizeChanges() + }, this.setSession = function(e) { + this.session = e, e && this.$computeTabString() + }, this.showInvisibles = !1, this.setShowInvisibles = function(e) { + return this.showInvisibles == e ? !1 : (this.showInvisibles = e, this.$computeTabString(), !0) + }, this.displayIndentGuides = !0, this.setDisplayIndentGuides = function(e) { + return this.displayIndentGuides == e ? !1 : (this.displayIndentGuides = e, this.$computeTabString(), !0) + }, this.$tabStrings = [], this.onChangeTabSize = this.$computeTabString = function() { + var e = this.session.getTabSize(); + this.tabSize = e; + var t = this.$tabStrings = [0]; + for (var n = 1; n < e + 1; n++) this.showInvisibles ? t.push("" + s.stringRepeat(this.TAB_CHAR, n) + "") : t.push(s.stringRepeat(" ", n)); + if (this.displayIndentGuides) { + this.$indentGuideRe = /\s\S| \t|\t |\s$/; + var r = "ace_indent-guide", + i = "", + o = ""; + if (this.showInvisibles) { + r += " ace_invisible", i = " ace_invisible_space", o = " ace_invisible_tab"; + var u = s.stringRepeat(this.SPACE_CHAR, this.tabSize), + a = s.stringRepeat(this.TAB_CHAR, this.tabSize) + } else var u = s.stringRepeat(" ", this.tabSize), + a = u; + this.$tabStrings[" "] = "" + u + "", this.$tabStrings[" "] = "" + a + "" + } + }, this.updateLines = function(e, t, n) { + (this.config.lastRow != e.lastRow || this.config.firstRow != e.firstRow) && this.scrollLines(e), this.config = e; + var r = Math.max(t, e.firstRow), + i = Math.min(n, e.lastRow), + s = this.element.childNodes, + o = 0; + for (var u = e.firstRow; u < r; u++) { + var a = this.session.getFoldLine(u); + if (a) { + if (a.containsRow(r)) { + r = a.start.row; + break + } + u = a.end.row + } + o++ + } + var u = r, + a = this.session.getNextFoldLine(u), + f = a ? a.start.row : Infinity; + for (;;) { + u > f && (u = a.end.row + 1, a = this.session.getNextFoldLine(u, a), f = a ? a.start.row : Infinity); + if (u > i) break; + var l = s[o++]; + if (l) { + var c = []; + this.$renderLine(c, u, !this.$useLineGroups(), u == f ? a : !1), l.style.height = e.lineHeight * this.session.getRowLength(u) + "px", l.innerHTML = c.join("") + } + u++ + } + }, this.scrollLines = function(e) { + var t = this.config; + this.config = e; + if (!t || t.lastRow < e.firstRow) return this.update(e); + if (e.lastRow < t.firstRow) return this.update(e); + var n = this.element; + if (t.firstRow < e.firstRow) + for (var r = this.session.getFoldedRowCount(t.firstRow, e.firstRow - 1); r > 0; r--) n.removeChild(n.firstChild); + if (t.lastRow > e.lastRow) + for (var r = this.session.getFoldedRowCount(e.lastRow + 1, t.lastRow); r > 0; r--) n.removeChild(n.lastChild); + if (e.firstRow < t.firstRow) { + var i = this.$renderLinesFragment(e, e.firstRow, t.firstRow - 1); + n.firstChild ? n.insertBefore(i, n.firstChild) : n.appendChild(i) + } + if (e.lastRow > t.lastRow) { + var i = this.$renderLinesFragment(e, t.lastRow + 1, e.lastRow); + n.appendChild(i) + } + }, this.$renderLinesFragment = function(e, t, n) { + var r = this.element.ownerDocument.createDocumentFragment(), + s = t, + o = this.session.getNextFoldLine(s), + u = o ? o.start.row : Infinity; + for (;;) { + s > u && (s = o.end.row + 1, o = this.session.getNextFoldLine(s, o), u = o ? o.start.row : Infinity); + if (s > n) break; + var a = i.createElement("div"), + f = []; + this.$renderLine(f, s, !1, s == u ? o : !1), a.innerHTML = f.join(""); + if (this.$useLineGroups()) a.className = "ace_line_group", r.appendChild(a), a.style.height = e.lineHeight * this.session.getRowLength(s) + "px"; + else + while (a.firstChild) r.appendChild(a.firstChild); + s++ + } + return r + }, this.update = function(e) { + this.config = e; + var t = [], + n = e.firstRow, + r = e.lastRow, + i = n, + s = this.session.getNextFoldLine(i), + o = s ? s.start.row : Infinity; + for (;;) { + i > o && (i = s.end.row + 1, s = this.session.getNextFoldLine(i, s), o = s ? s.start.row : Infinity); + if (i > r) break; + this.$useLineGroups() && t.push("
"), this.$renderLine(t, i, !1, i == o ? s : !1), this.$useLineGroups() && t.push("
"), i++ + } + this.element.innerHTML = t.join("") + }, this.$textToken = { + text: !0, + rparen: !0, + lparen: !0 + }, this.$renderToken = function(e, t, n, r) { + var i = this, + o = /\t|&|<|>|( +)|([\x00-\x1f\x80-\xa0\xad\u1680\u180E\u2000-\u200f\u2028\u2029\u202F\u205F\u3000\uFEFF\uFFF9-\uFFFC])|[\u1100-\u115F\u11A3-\u11A7\u11FA-\u11FF\u2329-\u232A\u2E80-\u2E99\u2E9B-\u2EF3\u2F00-\u2FD5\u2FF0-\u2FFB\u3000-\u303E\u3041-\u3096\u3099-\u30FF\u3105-\u312D\u3131-\u318E\u3190-\u31BA\u31C0-\u31E3\u31F0-\u321E\u3220-\u3247\u3250-\u32FE\u3300-\u4DBF\u4E00-\uA48C\uA490-\uA4C6\uA960-\uA97C\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFAFF\uFE10-\uFE19\uFE30-\uFE52\uFE54-\uFE66\uFE68-\uFE6B\uFF01-\uFF60\uFFE0-\uFFE6]|[\uD800-\uDBFF][\uDC00-\uDFFF]/g, + u = function(e, n, r, o, u) { + if (n) return i.showInvisibles ? "" + s.stringRepeat(i.SPACE_CHAR, e.length) + "" : e; + if (e == "&") return "&"; + if (e == "<") return "<"; + if (e == ">") return ">"; + if (e == " ") { + var a = i.session.getScreenTabSize(t + o); + return t += a - 1, i.$tabStrings[a] + } + if (e == "\u3000") { + var f = i.showInvisibles ? "ace_cjk ace_invisible ace_invisible_space" : "ace_cjk", + l = i.showInvisibles ? i.SPACE_CHAR : ""; + return t += 1, "" + l + "" + } + return r ? "" + i.SPACE_CHAR + "" : (t += 1, "" + e + "") + }, + a = r.replace(o, u); + if (!this.$textToken[n.type]) { + var f = "ace_" + n.type.replace(/\./g, " ace_"), + l = ""; + n.type == "fold" && (l = " style='width:" + n.value.length * this.config.characterWidth + "px;' "), e.push("", a, "") + } else e.push(a); + return t + r.length + }, this.renderIndentGuide = function(e, t, n) { + var r = t.search(this.$indentGuideRe); + return r <= 0 || r >= n ? t : t[0] == " " ? (r -= r % this.tabSize, e.push(s.stringRepeat(this.$tabStrings[" "], r / this.tabSize)), t.substr(r)) : t[0] == " " ? (e.push(s.stringRepeat(this.$tabStrings[" "], r)), t.substr(r)) : t + }, this.$renderWrappedLine = function(e, t, n, r) { + var i = 0, + o = 0, + u = n[0], + a = 0; + for (var f = 0; f < t.length; f++) { + var l = t[f], + c = l.value; + if (f == 0 && this.displayIndentGuides) { + i = c.length, c = this.renderIndentGuide(e, c, u); + if (!c) continue; + i -= c.length + } + if (i + c.length < u) a = this.$renderToken(e, a, l, c), i += c.length; + else { + while (i + c.length >= u) a = this.$renderToken(e, a, l, c.substring(0, u - i)), c = c.substring(u - i), i = u, r || e.push("
", "
"), e.push(s.stringRepeat("\u00a0", n.indent)), o++, a = 0, u = n[o] || Number.MAX_VALUE; + c.length != 0 && (i += c.length, a = this.$renderToken(e, a, l, c)) + } + } + }, this.$renderSimpleLine = function(e, t) { + var n = 0, + r = t[0], + i = r.value; + this.displayIndentGuides && (i = this.renderIndentGuide(e, i)), i && (n = this.$renderToken(e, n, r, i)); + for (var s = 1; s < t.length; s++) r = t[s], i = r.value, n = this.$renderToken(e, n, r, i) + }, this.$renderLine = function(e, t, n, r) { + !r && r != 0 && (r = this.session.getFoldLine(t)); + if (r) var i = this.$getFoldLineTokens(t, r); + else var i = this.session.getTokens(t); + n || e.push("
"); + if (i.length) { + var s = this.session.getRowSplitData(t); + s && s.length ? this.$renderWrappedLine(e, i, s, n) : this.$renderSimpleLine(e, i) + } + this.showInvisibles && (r && (t = r.end.row), e.push("", t == this.session.getLength() - 1 ? this.EOF_CHAR : this.EOL_CHAR, "")), n || e.push("
") + }, this.$getFoldLineTokens = function(e, t) { + function i(e, t, n) { + var i = 0, + s = 0; + while (s + e[i].value.length < t) { + s += e[i].value.length, i++; + if (i == e.length) return + } + if (s != t) { + var o = e[i].value.substring(t - s); + o.length > n - t && (o = o.substring(0, n - t)), r.push({ + type: e[i].type, + value: o + }), s = t + o.length, i += 1 + } + while (s < n && i < e.length) { + var o = e[i].value; + o.length + s > n ? r.push({ + type: e[i].type, + value: o.substring(0, n - s) + }) : r.push(e[i]), s += o.length, i += 1 + } + } + var n = this.session, + r = [], + s = n.getTokens(e); + return t.walk(function(e, t, o, u, a) { + e != null ? r.push({ + type: "fold", + value: e + }) : (a && (s = n.getTokens(t)), s.length && i(s, u, o)) + }, t.end.row, this.session.getLine(t.end.row).length), r + }, this.$useLineGroups = function() { + return this.session.getUseWrapMode() + }, this.destroy = function() { + clearInterval(this.$pollSizeChangesTimer), this.$measureNode && this.$measureNode.parentNode.removeChild(this.$measureNode), delete this.$measureNode + } + }).call(a.prototype), t.Text = a +}), define("ace/layer/cursor", ["require", "exports", "module", "ace/lib/dom"], function(e, t, n) { + "use strict"; + var r = e("../lib/dom"), + i, s = function(e) { + this.element = r.createElement("div"), this.element.className = "ace_layer ace_cursor-layer", e.appendChild(this.element), i === undefined && (i = !("opacity" in this.element.style)), this.isVisible = !1, this.isBlinking = !0, this.blinkInterval = 1e3, this.smoothBlinking = !1, this.cursors = [], this.cursor = this.addCursor(), r.addCssClass(this.element, "ace_hidden-cursors"), this.$updateCursors = (i ? this.$updateVisibility : this.$updateOpacity).bind(this) + }; + (function() { + this.$updateVisibility = function(e) { + var t = this.cursors; + for (var n = t.length; n--;) t[n].style.visibility = e ? "" : "hidden" + }, this.$updateOpacity = function(e) { + var t = this.cursors; + for (var n = t.length; n--;) t[n].style.opacity = e ? "" : "0" + }, this.$padding = 0, this.setPadding = function(e) { + this.$padding = e + }, this.setSession = function(e) { + this.session = e + }, this.setBlinking = function(e) { + e != this.isBlinking && (this.isBlinking = e, this.restartTimer()) + }, this.setBlinkInterval = function(e) { + e != this.blinkInterval && (this.blinkInterval = e, this.restartTimer()) + }, this.setSmoothBlinking = function(e) { + e != this.smoothBlinking && !i && (this.smoothBlinking = e, r.setCssClass(this.element, "ace_smooth-blinking", e), this.$updateCursors(!0), this.$updateCursors = this.$updateOpacity.bind(this), this.restartTimer()) + }, this.addCursor = function() { + var e = r.createElement("div"); + return e.className = "ace_cursor", this.element.appendChild(e), this.cursors.push(e), e + }, this.removeCursor = function() { + if (this.cursors.length > 1) { + var e = this.cursors.pop(); + return e.parentNode.removeChild(e), e + } + }, this.hideCursor = function() { + this.isVisible = !1, r.addCssClass(this.element, "ace_hidden-cursors"), this.restartTimer() + }, this.showCursor = function() { + this.isVisible = !0, r.removeCssClass(this.element, "ace_hidden-cursors"), this.restartTimer() + }, this.restartTimer = function() { + var e = this.$updateCursors; + clearInterval(this.intervalId), clearTimeout(this.timeoutId), this.smoothBlinking && r.removeCssClass(this.element, "ace_smooth-blinking"), e(!0); + if (!this.isBlinking || !this.blinkInterval || !this.isVisible) return; + this.smoothBlinking && setTimeout(function() { + r.addCssClass(this.element, "ace_smooth-blinking") + }.bind(this)); + var t = function() { + this.timeoutId = setTimeout(function() { + e(!1) + }, .6 * this.blinkInterval) + }.bind(this); + this.intervalId = setInterval(function() { + e(!0), t() + }, this.blinkInterval), t() + }, this.getPixelPosition = function(e, t) { + if (!this.config || !this.session) return { + left: 0, + top: 0 + }; + e || (e = this.session.selection.getCursor()); + var n = this.session.documentToScreenPosition(e), + r = this.$padding + (this.session.$bidiHandler.isBidiRow(n.row, e.row) ? this.session.$bidiHandler.getPosLeft(n.column) : n.column * this.config.characterWidth), + i = (n.row - (t ? this.config.firstRowScreen : 0)) * this.config.lineHeight; + return { + left: r, + top: i + } + }, this.update = function(e) { + this.config = e; + var t = this.session.$selectionMarkers, + n = 0, + r = 0; + if (t === undefined || t.length === 0) t = [{ + cursor: null + }]; + for (var n = 0, i = t.length; n < i; n++) { + var s = this.getPixelPosition(t[n].cursor, !0); + if ((s.top > e.height + e.offset || s.top < 0) && n > 1) continue; + var o = (this.cursors[r++] || this.addCursor()).style; + this.drawCursor ? this.drawCursor(o, s, e, t[n], this.session) : (o.left = s.left + "px", o.top = s.top + "px", o.width = e.characterWidth + "px", o.height = e.lineHeight + "px") + } + while (this.cursors.length > r) this.removeCursor(); + var u = this.session.getOverwrite(); + this.$setOverwrite(u), this.$pixelPos = s, this.restartTimer() + }, this.drawCursor = null, this.$setOverwrite = function(e) { + e != this.overwrite && (this.overwrite = e, e ? r.addCssClass(this.element, "ace_overwrite-cursors") : r.removeCssClass(this.element, "ace_overwrite-cursors")) + }, this.destroy = function() { + clearInterval(this.intervalId), clearTimeout(this.timeoutId) + } + }).call(s.prototype), t.Cursor = s +}), define("ace/scrollbar", ["require", "exports", "module", "ace/lib/oop", "ace/lib/dom", "ace/lib/event", "ace/lib/event_emitter"], function(e, t, n) { + "use strict"; + var r = e("./lib/oop"), + i = e("./lib/dom"), + s = e("./lib/event"), + o = e("./lib/event_emitter").EventEmitter, + u = 32768, + a = function(e) { + this.element = i.createElement("div"), this.element.className = "ace_scrollbar ace_scrollbar" + this.classSuffix, this.inner = i.createElement("div"), this.inner.className = "ace_scrollbar-inner", this.element.appendChild(this.inner), e.appendChild(this.element), this.setVisible(!1), this.skipEvent = !1, s.addListener(this.element, "scroll", this.onScroll.bind(this)), s.addListener(this.element, "mousedown", s.preventDefault) + }; + (function() { + r.implement(this, o), this.setVisible = function(e) { + this.element.style.display = e ? "" : "none", this.isVisible = e, this.coeff = 1 + } + }).call(a.prototype); + var f = function(e, t) { + a.call(this, e), this.scrollTop = 0, this.scrollHeight = 0, t.$scrollbarWidth = this.width = i.scrollbarWidth(e.ownerDocument), this.inner.style.width = this.element.style.width = (this.width || 15) + 5 + "px", this.$minWidth = 0 + }; + r.inherits(f, a), + function() { + this.classSuffix = "-v", this.onScroll = function() { + if (!this.skipEvent) { + this.scrollTop = this.element.scrollTop; + if (this.coeff != 1) { + var e = this.element.clientHeight / this.scrollHeight; + this.scrollTop = this.scrollTop * (1 - e) / (this.coeff - e) + } + this._emit("scroll", { + data: this.scrollTop + }) + } + this.skipEvent = !1 + }, this.getWidth = function() { + return Math.max(this.isVisible ? this.width : 0, this.$minWidth || 0) + }, this.setHeight = function(e) { + this.element.style.height = e + "px" + }, this.setInnerHeight = this.setScrollHeight = function(e) { + this.scrollHeight = e, e > u ? (this.coeff = u / e, e = u) : this.coeff != 1 && (this.coeff = 1), this.inner.style.height = e + "px" + }, this.setScrollTop = function(e) { + this.scrollTop != e && (this.skipEvent = !0, this.scrollTop = e, this.element.scrollTop = e * this.coeff) + } + }.call(f.prototype); + var l = function(e, t) { + a.call(this, e), this.scrollLeft = 0, this.height = t.$scrollbarWidth, this.inner.style.height = this.element.style.height = (this.height || 15) + 5 + "px" + }; + r.inherits(l, a), + function() { + this.classSuffix = "-h", this.onScroll = function() { + this.skipEvent || (this.scrollLeft = this.element.scrollLeft, this._emit("scroll", { + data: this.scrollLeft + })), this.skipEvent = !1 + }, this.getHeight = function() { + return this.isVisible ? this.height : 0 + }, this.setWidth = function(e) { + this.element.style.width = e + "px" + }, this.setInnerWidth = function(e) { + this.inner.style.width = e + "px" + }, this.setScrollWidth = function(e) { + this.inner.style.width = e + "px" + }, this.setScrollLeft = function(e) { + this.scrollLeft != e && (this.skipEvent = !0, this.scrollLeft = this.element.scrollLeft = e) + } + }.call(l.prototype), t.ScrollBar = f, t.ScrollBarV = f, t.ScrollBarH = l, t.VScrollBar = f, t.HScrollBar = l +}), define("ace/renderloop", ["require", "exports", "module", "ace/lib/event"], function(e, t, n) { + "use strict"; + var r = e("./lib/event"), + i = function(e, t) { + this.onRender = e, this.pending = !1, this.changes = 0, this.window = t || window + }; + (function() { + this.schedule = function(e) { + this.changes = this.changes | e; + if (!this.pending && this.changes) { + this.pending = !0; + var t = this; + r.nextFrame(function() { + t.pending = !1; + var e; + while (e = t.changes) t.changes = 0, t.onRender(e) + }, this.window) + } + } + }).call(i.prototype), t.RenderLoop = i +}), define("ace/layer/font_metrics", ["require", "exports", "module", "ace/lib/oop", "ace/lib/dom", "ace/lib/lang", "ace/lib/useragent", "ace/lib/event_emitter"], function(e, t, n) { + var r = e("../lib/oop"), + i = e("../lib/dom"), + s = e("../lib/lang"), + o = e("../lib/useragent"), + u = e("../lib/event_emitter").EventEmitter, + a = 0, + f = t.FontMetrics = function(e) { + this.el = i.createElement("div"), this.$setMeasureNodeStyles(this.el.style, !0), this.$main = i.createElement("div"), this.$setMeasureNodeStyles(this.$main.style), this.$measureNode = i.createElement("div"), this.$setMeasureNodeStyles(this.$measureNode.style), this.el.appendChild(this.$main), this.el.appendChild(this.$measureNode), e.appendChild(this.el), a || this.$testFractionalRect(), this.$measureNode.innerHTML = s.stringRepeat("X", a), this.$characterSize = { + width: 0, + height: 0 + }, this.checkForSizeChanges() + }; + (function() { + r.implement(this, u), this.$characterSize = { + width: 0, + height: 0 + }, this.$testFractionalRect = function() { + var e = i.createElement("div"); + this.$setMeasureNodeStyles(e.style), e.style.width = "0.2px", document.documentElement.appendChild(e); + var t = e.getBoundingClientRect().width; + t > 0 && t < 1 ? a = 50 : a = 100, e.parentNode.removeChild(e) + }, this.$setMeasureNodeStyles = function(e, t) { + e.width = e.height = "auto", e.left = e.top = "0px", e.visibility = "hidden", e.position = "absolute", e.whiteSpace = "pre", o.isIE < 8 ? e["font-family"] = "inherit" : e.font = "inherit", e.overflow = t ? "hidden" : "visible" + }, this.checkForSizeChanges = function() { + var e = this.$measureSizes(); + if (e && (this.$characterSize.width !== e.width || this.$characterSize.height !== e.height)) { + this.$measureNode.style.fontWeight = "bold"; + var t = this.$measureSizes(); + this.$measureNode.style.fontWeight = "", this.$characterSize = e, this.charSizes = Object.create(null), this.allowBoldFonts = t && t.width === e.width && t.height === e.height, this._emit("changeCharacterSize", { + data: e + }) + } + }, this.$pollSizeChanges = function() { + if (this.$pollSizeChangesTimer) return this.$pollSizeChangesTimer; + var e = this; + return this.$pollSizeChangesTimer = setInterval(function() { + e.checkForSizeChanges() + }, 500) + }, this.setPolling = function(e) { + e ? this.$pollSizeChanges() : this.$pollSizeChangesTimer && (clearInterval(this.$pollSizeChangesTimer), this.$pollSizeChangesTimer = 0) + }, this.$measureSizes = function() { + if (a === 50) { + var e = null; + try { + e = this.$measureNode.getBoundingClientRect() + } catch (t) { + e = { + width: 0, + height: 0 + } + } + var n = { + height: e.height, + width: e.width / a + } + } else var n = { + height: this.$measureNode.clientHeight, + width: this.$measureNode.clientWidth / a + }; + return n.width === 0 || n.height === 0 ? null : n + }, this.$measureCharWidth = function(e) { + this.$main.innerHTML = s.stringRepeat(e, a); + var t = this.$main.getBoundingClientRect(); + return t.width / a + }, this.getCharacterWidth = function(e) { + var t = this.charSizes[e]; + return t === undefined && (t = this.charSizes[e] = this.$measureCharWidth(e) / this.$characterSize.width), t + }, this.destroy = function() { + clearInterval(this.$pollSizeChangesTimer), this.el && this.el.parentNode && this.el.parentNode.removeChild(this.el) + } + }).call(f.prototype) +}), define("ace/virtual_renderer", ["require", "exports", "module", "ace/lib/oop", "ace/lib/dom", "ace/config", "ace/lib/useragent", "ace/layer/gutter", "ace/layer/marker", "ace/layer/text", "ace/layer/cursor", "ace/scrollbar", "ace/scrollbar", "ace/renderloop", "ace/layer/font_metrics", "ace/lib/event_emitter"], function(e, t, n) { + "use strict"; + var r = e("./lib/oop"), + i = e("./lib/dom"), + s = e("./config"), + o = e("./lib/useragent"), + u = e("./layer/gutter").Gutter, + a = e("./layer/marker").Marker, + f = e("./layer/text").Text, + l = e("./layer/cursor").Cursor, + c = e("./scrollbar").HScrollBar, + h = e("./scrollbar").VScrollBar, + p = e("./renderloop").RenderLoop, + d = e("./layer/font_metrics").FontMetrics, + v = e("./lib/event_emitter").EventEmitter, + m = '.ace_editor {position: relative;overflow: hidden;font: 12px/normal \'Monaco\', \'Menlo\', \'Ubuntu Mono\', \'Consolas\', \'source-code-pro\', monospace;direction: ltr;text-align: left;-webkit-tap-highlight-color: rgba(0, 0, 0, 0);}.ace_scroller {position: absolute;overflow: hidden;top: 0;bottom: 0;background-color: inherit;-ms-user-select: none;-moz-user-select: none;-webkit-user-select: none;user-select: none;cursor: text;}.ace_content {position: absolute;-moz-box-sizing: border-box;-webkit-box-sizing: border-box;box-sizing: border-box;min-width: 100%;}.ace_dragging .ace_scroller:before{position: absolute;top: 0;left: 0;right: 0;bottom: 0;content: \'\';background: rgba(250, 250, 250, 0.01);z-index: 1000;}.ace_dragging.ace_dark .ace_scroller:before{background: rgba(0, 0, 0, 0.01);}.ace_selecting, .ace_selecting * {cursor: text !important;}.ace_gutter {position: absolute;overflow : hidden;width: auto;top: 0;bottom: 0;left: 0;cursor: default;z-index: 4;-ms-user-select: none;-moz-user-select: none;-webkit-user-select: none;user-select: none;}.ace_gutter-active-line {position: absolute;left: 0;right: 0;}.ace_scroller.ace_scroll-left {box-shadow: 17px 0 16px -16px rgba(0, 0, 0, 0.4) inset;}.ace_gutter-cell {padding-left: 19px;padding-right: 6px;background-repeat: no-repeat;}.ace_gutter-cell.ace_error {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAABOFBMVEX/////////QRswFAb/Ui4wFAYwFAYwFAaWGAfDRymzOSH/PxswFAb/SiUwFAYwFAbUPRvjQiDllog5HhHdRybsTi3/Tyv9Tir+Syj/UC3////XurebMBIwFAb/RSHbPx/gUzfdwL3kzMivKBAwFAbbvbnhPx66NhowFAYwFAaZJg8wFAaxKBDZurf/RB6mMxb/SCMwFAYwFAbxQB3+RB4wFAb/Qhy4Oh+4QifbNRcwFAYwFAYwFAb/QRzdNhgwFAYwFAbav7v/Uy7oaE68MBK5LxLewr/r2NXewLswFAaxJw4wFAbkPRy2PyYwFAaxKhLm1tMwFAazPiQwFAaUGAb/QBrfOx3bvrv/VC/maE4wFAbRPBq6MRO8Qynew8Dp2tjfwb0wFAbx6eju5+by6uns4uH9/f36+vr/GkHjAAAAYnRSTlMAGt+64rnWu/bo8eAA4InH3+DwoN7j4eLi4xP99Nfg4+b+/u9B/eDs1MD1mO7+4PHg2MXa347g7vDizMLN4eG+Pv7i5evs/v79yu7S3/DV7/498Yv24eH+4ufQ3Ozu/v7+y13sRqwAAADLSURBVHjaZc/XDsFgGIBhtDrshlitmk2IrbHFqL2pvXf/+78DPokj7+Fz9qpU/9UXJIlhmPaTaQ6QPaz0mm+5gwkgovcV6GZzd5JtCQwgsxoHOvJO15kleRLAnMgHFIESUEPmawB9ngmelTtipwwfASilxOLyiV5UVUyVAfbG0cCPHig+GBkzAENHS0AstVF6bacZIOzgLmxsHbt2OecNgJC83JERmePUYq8ARGkJx6XtFsdddBQgZE2nPR6CICZhawjA4Fb/chv+399kfR+MMMDGOQAAAABJRU5ErkJggg==");background-repeat: no-repeat;background-position: 2px center;}.ace_gutter-cell.ace_warning {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAAAmVBMVEX///8AAAD///8AAAAAAABPSzb/5sAAAAB/blH/73z/ulkAAAAAAAD85pkAAAAAAAACAgP/vGz/rkDerGbGrV7/pkQICAf////e0IsAAAD/oED/qTvhrnUAAAD/yHD/njcAAADuv2r/nz//oTj/p064oGf/zHAAAAA9Nir/tFIAAAD/tlTiuWf/tkIAAACynXEAAAAAAAAtIRW7zBpBAAAAM3RSTlMAABR1m7RXO8Ln31Z36zT+neXe5OzooRDfn+TZ4p3h2hTf4t3k3ucyrN1K5+Xaks52Sfs9CXgrAAAAjklEQVR42o3PbQ+CIBQFYEwboPhSYgoYunIqqLn6/z8uYdH8Vmdnu9vz4WwXgN/xTPRD2+sgOcZjsge/whXZgUaYYvT8QnuJaUrjrHUQreGczuEafQCO/SJTufTbroWsPgsllVhq3wJEk2jUSzX3CUEDJC84707djRc5MTAQxoLgupWRwW6UB5fS++NV8AbOZgnsC7BpEAAAAABJRU5ErkJggg==");background-position: 2px center;}.ace_gutter-cell.ace_info {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAAAAAA6mKC9AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAAJ0Uk5TAAB2k804AAAAPklEQVQY02NgIB68QuO3tiLznjAwpKTgNyDbMegwisCHZUETUZV0ZqOquBpXj2rtnpSJT1AEnnRmL2OgGgAAIKkRQap2htgAAAAASUVORK5CYII=");background-position: 2px center;}.ace_dark .ace_gutter-cell.ace_info {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQBAMAAADt3eJSAAAAJFBMVEUAAAChoaGAgIAqKiq+vr6tra1ZWVmUlJSbm5s8PDxubm56enrdgzg3AAAAAXRSTlMAQObYZgAAAClJREFUeNpjYMAPdsMYHegyJZFQBlsUlMFVCWUYKkAZMxZAGdxlDMQBAG+TBP4B6RyJAAAAAElFTkSuQmCC");}.ace_scrollbar {position: absolute;right: 0;bottom: 0;z-index: 6;}.ace_scrollbar-inner {position: absolute;cursor: text;left: 0;top: 0;}.ace_scrollbar-v{overflow-x: hidden;overflow-y: scroll;top: 0;}.ace_scrollbar-h {overflow-x: scroll;overflow-y: hidden;left: 0;}.ace_print-margin {position: absolute;height: 100%;}.ace_text-input {position: absolute;z-index: 0;width: 0.5em;height: 1em;opacity: 0;background: transparent;-moz-appearance: none;appearance: none;border: none;resize: none;outline: none;overflow: hidden;font: inherit;padding: 0 1px;margin: 0 -1px;text-indent: -1em;-ms-user-select: text;-moz-user-select: text;-webkit-user-select: text;user-select: text;white-space: pre!important;}.ace_text-input.ace_composition {background: inherit;color: inherit;z-index: 1000;opacity: 1;text-indent: 0;}.ace_layer {z-index: 1;position: absolute;overflow: hidden;word-wrap: normal;white-space: pre;height: 100%;width: 100%;-moz-box-sizing: border-box;-webkit-box-sizing: border-box;box-sizing: border-box;pointer-events: none;}.ace_gutter-layer {position: relative;width: auto;text-align: right;pointer-events: auto;}.ace_text-layer {font: inherit !important;}.ace_cjk {display: inline-block;text-align: center;}.ace_cursor-layer {z-index: 4;}.ace_cursor {z-index: 4;position: absolute;-moz-box-sizing: border-box;-webkit-box-sizing: border-box;box-sizing: border-box;border-left: 2px solid;transform: translatez(0);}.ace_multiselect .ace_cursor {border-left-width: 1px;}.ace_slim-cursors .ace_cursor {border-left-width: 1px;}.ace_overwrite-cursors .ace_cursor {border-left-width: 0;border-bottom: 1px solid;}.ace_hidden-cursors .ace_cursor {opacity: 0.2;}.ace_smooth-blinking .ace_cursor {-webkit-transition: opacity 0.18s;transition: opacity 0.18s;}.ace_marker-layer .ace_step, .ace_marker-layer .ace_stack {position: absolute;z-index: 3;}.ace_marker-layer .ace_selection {position: absolute;z-index: 5;}.ace_marker-layer .ace_bracket {position: absolute;z-index: 6;}.ace_marker-layer .ace_active-line {position: absolute;z-index: 2;}.ace_marker-layer .ace_selected-word {position: absolute;z-index: 4;-moz-box-sizing: border-box;-webkit-box-sizing: border-box;box-sizing: border-box;}.ace_line .ace_fold {-moz-box-sizing: border-box;-webkit-box-sizing: border-box;box-sizing: border-box;display: inline-block;height: 11px;margin-top: -2px;vertical-align: middle;background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABEAAAAJCAYAAADU6McMAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAJpJREFUeNpi/P//PwOlgAXGYGRklAVSokD8GmjwY1wasKljQpYACtpCFeADcHVQfQyMQAwzwAZI3wJKvCLkfKBaMSClBlR7BOQikCFGQEErIH0VqkabiGCAqwUadAzZJRxQr/0gwiXIal8zQQPnNVTgJ1TdawL0T5gBIP1MUJNhBv2HKoQHHjqNrA4WO4zY0glyNKLT2KIfIMAAQsdgGiXvgnYAAAAASUVORK5CYII="),url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAA3CAYAAADNNiA5AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAACJJREFUeNpi+P//fxgTAwPDBxDxD078RSX+YeEyDFMCIMAAI3INmXiwf2YAAAAASUVORK5CYII=");background-repeat: no-repeat, repeat-x;background-position: center center, top left;color: transparent;border: 1px solid black;border-radius: 2px;cursor: pointer;pointer-events: auto;}.ace_dark .ace_fold {}.ace_fold:hover{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABEAAAAJCAYAAADU6McMAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAJpJREFUeNpi/P//PwOlgAXGYGRklAVSokD8GmjwY1wasKljQpYACtpCFeADcHVQfQyMQAwzwAZI3wJKvCLkfKBaMSClBlR7BOQikCFGQEErIH0VqkabiGCAqwUadAzZJRxQr/0gwiXIal8zQQPnNVTgJ1TdawL0T5gBIP1MUJNhBv2HKoQHHjqNrA4WO4zY0glyNKLT2KIfIMAAQsdgGiXvgnYAAAAASUVORK5CYII="),url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAA3CAYAAADNNiA5AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAACBJREFUeNpi+P//fz4TAwPDZxDxD5X4i5fLMEwJgAADAEPVDbjNw87ZAAAAAElFTkSuQmCC");}.ace_tooltip {background-color: #FFF;background-image: -webkit-linear-gradient(top, transparent, rgba(0, 0, 0, 0.1));background-image: linear-gradient(to bottom, transparent, rgba(0, 0, 0, 0.1));border: 1px solid gray;border-radius: 1px;box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);color: black;max-width: 100%;padding: 3px 4px;position: fixed;z-index: 999999;-moz-box-sizing: border-box;-webkit-box-sizing: border-box;box-sizing: border-box;cursor: default;white-space: pre;word-wrap: break-word;line-height: normal;font-style: normal;font-weight: normal;letter-spacing: normal;pointer-events: none;}.ace_folding-enabled > .ace_gutter-cell {padding-right: 13px;}.ace_fold-widget {-moz-box-sizing: border-box;-webkit-box-sizing: border-box;box-sizing: border-box;margin: 0 -12px 0 1px;display: none;width: 11px;vertical-align: top;background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAANElEQVR42mWKsQ0AMAzC8ixLlrzQjzmBiEjp0A6WwBCSPgKAXoLkqSot7nN3yMwR7pZ32NzpKkVoDBUxKAAAAABJRU5ErkJggg==");background-repeat: no-repeat;background-position: center;border-radius: 3px;border: 1px solid transparent;cursor: pointer;}.ace_folding-enabled .ace_fold-widget {display: inline-block; }.ace_fold-widget.ace_end {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAANElEQVR42m3HwQkAMAhD0YzsRchFKI7sAikeWkrxwScEB0nh5e7KTPWimZki4tYfVbX+MNl4pyZXejUO1QAAAABJRU5ErkJggg==");}.ace_fold-widget.ace_closed {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAMAAAAGCAYAAAAG5SQMAAAAOUlEQVR42jXKwQkAMAgDwKwqKD4EwQ26sSOkVWjgIIHAzPiCgaqiqnJHZnKICBERHN194O5b9vbLuAVRL+l0YWnZAAAAAElFTkSuQmCCXA==");}.ace_fold-widget:hover {border: 1px solid rgba(0, 0, 0, 0.3);background-color: rgba(255, 255, 255, 0.2);box-shadow: 0 1px 1px rgba(255, 255, 255, 0.7);}.ace_fold-widget:active {border: 1px solid rgba(0, 0, 0, 0.4);background-color: rgba(0, 0, 0, 0.05);box-shadow: 0 1px 1px rgba(255, 255, 255, 0.8);}.ace_dark .ace_fold-widget {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHklEQVQIW2P4//8/AzoGEQ7oGCaLLAhWiSwB146BAQCSTPYocqT0AAAAAElFTkSuQmCC");}.ace_dark .ace_fold-widget.ace_end {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAH0lEQVQIW2P4//8/AxQ7wNjIAjDMgC4AxjCVKBirIAAF0kz2rlhxpAAAAABJRU5ErkJggg==");}.ace_dark .ace_fold-widget.ace_closed {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAMAAAAFCAYAAACAcVaiAAAAHElEQVQIW2P4//+/AxAzgDADlOOAznHAKgPWAwARji8UIDTfQQAAAABJRU5ErkJggg==");}.ace_dark .ace_fold-widget:hover {box-shadow: 0 1px 1px rgba(255, 255, 255, 0.2);background-color: rgba(255, 255, 255, 0.1);}.ace_dark .ace_fold-widget:active {box-shadow: 0 1px 1px rgba(255, 255, 255, 0.2);}.ace_fold-widget.ace_invalid {background-color: #FFB4B4;border-color: #DE5555;}.ace_fade-fold-widgets .ace_fold-widget {-webkit-transition: opacity 0.4s ease 0.05s;transition: opacity 0.4s ease 0.05s;opacity: 0;}.ace_fade-fold-widgets:hover .ace_fold-widget {-webkit-transition: opacity 0.05s ease 0.05s;transition: opacity 0.05s ease 0.05s;opacity:1;}.ace_underline {text-decoration: underline;}.ace_bold {font-weight: bold;}.ace_nobold .ace_bold {font-weight: normal;}.ace_italic {font-style: italic;}.ace_error-marker {background-color: rgba(255, 0, 0,0.2);position: absolute;z-index: 9;}.ace_highlight-marker {background-color: rgba(255, 255, 0,0.2);position: absolute;z-index: 8;}.ace_br1 {border-top-left-radius : 3px;}.ace_br2 {border-top-right-radius : 3px;}.ace_br3 {border-top-left-radius : 3px; border-top-right-radius: 3px;}.ace_br4 {border-bottom-right-radius: 3px;}.ace_br5 {border-top-left-radius : 3px; border-bottom-right-radius: 3px;}.ace_br6 {border-top-right-radius : 3px; border-bottom-right-radius: 3px;}.ace_br7 {border-top-left-radius : 3px; border-top-right-radius: 3px; border-bottom-right-radius: 3px;}.ace_br8 {border-bottom-left-radius : 3px;}.ace_br9 {border-top-left-radius : 3px; border-bottom-left-radius: 3px;}.ace_br10{border-top-right-radius : 3px; border-bottom-left-radius: 3px;}.ace_br11{border-top-left-radius : 3px; border-top-right-radius: 3px; border-bottom-left-radius: 3px;}.ace_br12{border-bottom-right-radius: 3px; border-bottom-left-radius: 3px;}.ace_br13{border-top-left-radius : 3px; border-bottom-right-radius: 3px; border-bottom-left-radius: 3px;}.ace_br14{border-top-right-radius : 3px; border-bottom-right-radius: 3px; border-bottom-left-radius: 3px;}.ace_br15{border-top-left-radius : 3px; border-top-right-radius: 3px; border-bottom-right-radius: 3px; border-bottom-left-radius: 3px;}.ace_text-input-ios {position: absolute !important;top: -100000px !important;left: -100000px !important;}'; + i.importCssString(m, "ace_editor.css"); + var g = function(e, t) { + var n = this; + this.container = e || i.createElement("div"), this.$keepTextAreaAtCursor = !o.isOldIE, i.addCssClass(this.container, "ace_editor"), this.setTheme(t), this.$gutter = i.createElement("div"), this.$gutter.className = "ace_gutter", this.container.appendChild(this.$gutter), this.$gutter.setAttribute("aria-hidden", !0), this.scroller = i.createElement("div"), this.scroller.className = "ace_scroller", this.container.appendChild(this.scroller), this.content = i.createElement("div"), this.content.className = "ace_content", this.scroller.appendChild(this.content), this.$gutterLayer = new u(this.$gutter), this.$gutterLayer.on("changeGutterWidth", this.onGutterResize.bind(this)), this.$markerBack = new a(this.content); + var r = this.$textLayer = new f(this.content); + this.canvas = r.element, this.$markerFront = new a(this.content), this.$cursorLayer = new l(this.content), this.$horizScroll = !1, this.$vScroll = !1, this.scrollBar = this.scrollBarV = new h(this.container, this), this.scrollBarH = new c(this.container, this), this.scrollBarV.addEventListener("scroll", function(e) { + n.$scrollAnimation || n.session.setScrollTop(e.data - n.scrollMargin.top) + }), this.scrollBarH.addEventListener("scroll", function(e) { + n.$scrollAnimation || n.session.setScrollLeft(e.data - n.scrollMargin.left) + }), this.scrollTop = 0, this.scrollLeft = 0, this.cursorPos = { + row: 0, + column: 0 + }, this.$fontMetrics = new d(this.container), this.$textLayer.$setFontMetrics(this.$fontMetrics), this.$textLayer.addEventListener("changeCharacterSize", function(e) { + n.updateCharacterSize(), n.onResize(!0, n.gutterWidth, n.$size.width, n.$size.height), n._signal("changeCharacterSize", e) + }), this.$size = { + width: 0, + height: 0, + scrollerHeight: 0, + scrollerWidth: 0, + $dirty: !0 + }, this.layerConfig = { + width: 1, + padding: 0, + firstRow: 0, + firstRowScreen: 0, + lastRow: 0, + lineHeight: 0, + characterWidth: 0, + minHeight: 1, + maxHeight: 1, + offset: 0, + height: 1, + gutterOffset: 1 + }, this.scrollMargin = { + left: 0, + right: 0, + top: 0, + bottom: 0, + v: 0, + h: 0 + }, this.$loop = new p(this.$renderChanges.bind(this), this.container.ownerDocument.defaultView), this.$loop.schedule(this.CHANGE_FULL), this.updateCharacterSize(), this.setPadding(4), s.resetOptions(this), s._emit("renderer", this) + }; + (function() { + this.CHANGE_CURSOR = 1, this.CHANGE_MARKER = 2, this.CHANGE_GUTTER = 4, this.CHANGE_SCROLL = 8, this.CHANGE_LINES = 16, this.CHANGE_TEXT = 32, this.CHANGE_SIZE = 64, this.CHANGE_MARKER_BACK = 128, this.CHANGE_MARKER_FRONT = 256, this.CHANGE_FULL = 512, this.CHANGE_H_SCROLL = 1024, r.implement(this, v), this.updateCharacterSize = function() { + this.$textLayer.allowBoldFonts != this.$allowBoldFonts && (this.$allowBoldFonts = this.$textLayer.allowBoldFonts, this.setStyle("ace_nobold", !this.$allowBoldFonts)), this.layerConfig.characterWidth = this.characterWidth = this.$textLayer.getCharacterWidth(), this.layerConfig.lineHeight = this.lineHeight = this.$textLayer.getLineHeight(), this.$updatePrintMargin() + }, this.setSession = function(e) { + this.session && this.session.doc.off("changeNewLineMode", this.onChangeNewLineMode), this.session = e, e && this.scrollMargin.top && e.getScrollTop() <= 0 && e.setScrollTop(-this.scrollMargin.top), this.$cursorLayer.setSession(e), this.$markerBack.setSession(e), this.$markerFront.setSession(e), this.$gutterLayer.setSession(e), this.$textLayer.setSession(e); + if (!e) return; + this.$loop.schedule(this.CHANGE_FULL), this.session.$setFontMetrics(this.$fontMetrics), this.scrollBarH.scrollLeft = this.scrollBarV.scrollTop = null, this.onChangeNewLineMode = this.onChangeNewLineMode.bind(this), this.onChangeNewLineMode(), this.session.doc.on("changeNewLineMode", this.onChangeNewLineMode) + }, this.updateLines = function(e, t, n) { + t === undefined && (t = Infinity), this.$changedLines ? (this.$changedLines.firstRow > e && (this.$changedLines.firstRow = e), this.$changedLines.lastRow < t && (this.$changedLines.lastRow = t)) : this.$changedLines = { + firstRow: e, + lastRow: t + }; + if (this.$changedLines.lastRow < this.layerConfig.firstRow) { + if (!n) return; + this.$changedLines.lastRow = this.layerConfig.lastRow + } + if (this.$changedLines.firstRow > this.layerConfig.lastRow) return; + this.$loop.schedule(this.CHANGE_LINES) + }, this.onChangeNewLineMode = function() { + this.$loop.schedule(this.CHANGE_TEXT), this.$textLayer.$updateEolChar(), this.session.$bidiHandler.setEolChar(this.$textLayer.EOL_CHAR) + }, this.onChangeTabSize = function() { + this.$loop.schedule(this.CHANGE_TEXT | this.CHANGE_MARKER), this.$textLayer.onChangeTabSize() + }, this.updateText = function() { + this.$loop.schedule(this.CHANGE_TEXT) + }, this.updateFull = function(e) { + e ? this.$renderChanges(this.CHANGE_FULL, !0) : this.$loop.schedule(this.CHANGE_FULL) + }, this.updateFontSize = function() { + this.$textLayer.checkForSizeChanges() + }, this.$changes = 0, this.$updateSizeAsync = function() { + this.$loop.pending ? this.$size.$dirty = !0 : this.onResize() + }, this.onResize = function(e, t, n, r) { + if (this.resizing > 2) return; + this.resizing > 0 ? this.resizing++ : this.resizing = e ? 1 : 0; + var i = this.container; + r || (r = i.clientHeight || i.scrollHeight), n || (n = i.clientWidth || i.scrollWidth); + var s = this.$updateCachedSize(e, t, n, r); + if (!this.$size.scrollerHeight || !n && !r) return this.resizing = 0; + e && (this.$gutterLayer.$padding = null), e ? this.$renderChanges(s | this.$changes, !0) : this.$loop.schedule(s | this.$changes), this.resizing && (this.resizing = 0), this.scrollBarV.scrollLeft = this.scrollBarV.scrollTop = null + }, this.$updateCachedSize = function(e, t, n, r) { + r -= this.$extraHeight || 0; + var i = 0, + s = this.$size, + o = { + width: s.width, + height: s.height, + scrollerHeight: s.scrollerHeight, + scrollerWidth: s.scrollerWidth + }; + r && (e || s.height != r) && (s.height = r, i |= this.CHANGE_SIZE, s.scrollerHeight = s.height, this.$horizScroll && (s.scrollerHeight -= this.scrollBarH.getHeight()), this.scrollBarV.element.style.bottom = this.scrollBarH.getHeight() + "px", i |= this.CHANGE_SCROLL); + if (n && (e || s.width != n)) { + i |= this.CHANGE_SIZE, s.width = n, t == null && (t = this.$showGutter ? this.$gutter.offsetWidth : 0), this.gutterWidth = t, this.scrollBarH.element.style.left = this.scroller.style.left = t + "px", s.scrollerWidth = Math.max(0, n - t - this.scrollBarV.getWidth()), this.scrollBarH.element.style.right = this.scroller.style.right = this.scrollBarV.getWidth() + "px", this.scroller.style.bottom = this.scrollBarH.getHeight() + "px"; + if (this.session && this.session.getUseWrapMode() && this.adjustWrapLimit() || e) i |= this.CHANGE_FULL + } + return s.$dirty = !n || !r, i && this._signal("resize", o), i + }, this.onGutterResize = function() { + var e = this.$showGutter ? this.$gutter.offsetWidth : 0; + e != this.gutterWidth && (this.$changes |= this.$updateCachedSize(!0, e, this.$size.width, this.$size.height)), this.session.getUseWrapMode() && this.adjustWrapLimit() ? this.$loop.schedule(this.CHANGE_FULL) : this.$size.$dirty ? this.$loop.schedule(this.CHANGE_FULL) : (this.$computeLayerConfig(), this.$loop.schedule(this.CHANGE_MARKER)) + }, this.adjustWrapLimit = function() { + var e = this.$size.scrollerWidth - this.$padding * 2, + t = Math.floor(e / this.characterWidth); + return this.session.adjustWrapLimit(t, this.$showPrintMargin && this.$printMarginColumn) + }, this.setAnimatedScroll = function(e) { + this.setOption("animatedScroll", e) + }, this.getAnimatedScroll = function() { + return this.$animatedScroll + }, this.setShowInvisibles = function(e) { + this.setOption("showInvisibles", e), this.session.$bidiHandler.setShowInvisibles(e) + }, this.getShowInvisibles = function() { + return this.getOption("showInvisibles") + }, this.getDisplayIndentGuides = function() { + return this.getOption("displayIndentGuides") + }, this.setDisplayIndentGuides = function(e) { + this.setOption("displayIndentGuides", e) + }, this.setShowPrintMargin = function(e) { + this.setOption("showPrintMargin", e) + }, this.getShowPrintMargin = function() { + return this.getOption("showPrintMargin") + }, this.setPrintMarginColumn = function(e) { + this.setOption("printMarginColumn", e) + }, this.getPrintMarginColumn = function() { + return this.getOption("printMarginColumn") + }, this.getShowGutter = function() { + return this.getOption("showGutter") + }, this.setShowGutter = function(e) { + return this.setOption("showGutter", e) + }, this.getFadeFoldWidgets = function() { + return this.getOption("fadeFoldWidgets") + }, this.setFadeFoldWidgets = function(e) { + this.setOption("fadeFoldWidgets", e) + }, this.setHighlightGutterLine = function(e) { + this.setOption("highlightGutterLine", e) + }, this.getHighlightGutterLine = function() { + return this.getOption("highlightGutterLine") + }, this.$updateGutterLineHighlight = function() { + var e = this.$cursorLayer.$pixelPos, + t = this.layerConfig.lineHeight; + if (this.session.getUseWrapMode()) { + var n = this.session.selection.getCursor(); + n.column = 0, e = this.$cursorLayer.getPixelPosition(n, !0), t *= this.session.getRowLength(n.row) + } + this.$gutterLineHighlight.style.top = e.top - this.layerConfig.offset + "px", this.$gutterLineHighlight.style.height = t + "px" + }, this.$updatePrintMargin = function() { + if (!this.$showPrintMargin && !this.$printMarginEl) return; + if (!this.$printMarginEl) { + var e = i.createElement("div"); + e.className = "ace_layer ace_print-margin-layer", this.$printMarginEl = i.createElement("div"), this.$printMarginEl.className = "ace_print-margin", e.appendChild(this.$printMarginEl), this.content.insertBefore(e, this.content.firstChild) + } + var t = this.$printMarginEl.style; + t.left = this.characterWidth * this.$printMarginColumn + this.$padding + "px", t.visibility = this.$showPrintMargin ? "visible" : "hidden", this.session && this.session.$wrap == -1 && this.adjustWrapLimit() + }, this.getContainerElement = function() { + return this.container + }, this.getMouseEventTarget = function() { + return this.scroller + }, this.getTextAreaContainer = function() { + return this.container + }, this.$moveTextAreaToCursor = function() { + if (!this.$keepTextAreaAtCursor) return; + var e = this.layerConfig, + t = this.$cursorLayer.$pixelPos.top, + n = this.$cursorLayer.$pixelPos.left; + t -= e.offset; + var r = this.textarea.style, + i = this.lineHeight; + if (t < 0 || t > e.height - i) { + r.top = r.left = "0"; + return + } + var s = this.characterWidth; + if (this.$composition) { + var o = this.textarea.value.replace(/^\x01+/, ""); + s *= this.session.$getStringScreenWidth(o)[0] + 2, i += 2 + } + n -= this.scrollLeft, n > this.$size.scrollerWidth - s && (n = this.$size.scrollerWidth - s), n += this.gutterWidth, r.height = i + "px", r.width = s + "px", r.left = Math.min(n, this.$size.scrollerWidth - s) + "px", r.top = Math.min(t, this.$size.height - i) + "px" + }, this.getFirstVisibleRow = function() { + return this.layerConfig.firstRow + }, this.getFirstFullyVisibleRow = function() { + return this.layerConfig.firstRow + (this.layerConfig.offset === 0 ? 0 : 1) + }, this.getLastFullyVisibleRow = function() { + var e = this.layerConfig, + t = e.lastRow, + n = this.session.documentToScreenRow(t, 0) * e.lineHeight; + return n - this.session.getScrollTop() > e.height - e.lineHeight ? t - 1 : t + }, this.getLastVisibleRow = function() { + return this.layerConfig.lastRow + }, this.$padding = null, this.setPadding = function(e) { + this.$padding = e, this.$textLayer.setPadding(e), this.$cursorLayer.setPadding(e), this.$markerFront.setPadding(e), this.$markerBack.setPadding(e), this.$loop.schedule(this.CHANGE_FULL), this.$updatePrintMargin() + }, this.setScrollMargin = function(e, t, n, r) { + var i = this.scrollMargin; + i.top = e | 0, i.bottom = t | 0, i.right = r | 0, i.left = n | 0, i.v = i.top + i.bottom, i.h = i.left + i.right, i.top && this.scrollTop <= 0 && this.session && this.session.setScrollTop(-i.top), this.updateFull() + }, this.getHScrollBarAlwaysVisible = function() { + return this.$hScrollBarAlwaysVisible + }, this.setHScrollBarAlwaysVisible = function(e) { + this.setOption("hScrollBarAlwaysVisible", e) + }, this.getVScrollBarAlwaysVisible = function() { + return this.$vScrollBarAlwaysVisible + }, this.setVScrollBarAlwaysVisible = function(e) { + this.setOption("vScrollBarAlwaysVisible", e) + }, this.$updateScrollBarV = function() { + var e = this.layerConfig.maxHeight, + t = this.$size.scrollerHeight; + !this.$maxLines && this.$scrollPastEnd && (e -= (t - this.lineHeight) * this.$scrollPastEnd, this.scrollTop > e - t && (e = this.scrollTop + t, this.scrollBarV.scrollTop = null)), this.scrollBarV.setScrollHeight(e + this.scrollMargin.v), this.scrollBarV.setScrollTop(this.scrollTop + this.scrollMargin.top) + }, this.$updateScrollBarH = function() { + this.scrollBarH.setScrollWidth(this.layerConfig.width + 2 * this.$padding + this.scrollMargin.h), this.scrollBarH.setScrollLeft(this.scrollLeft + this.scrollMargin.left) + }, this.$frozen = !1, this.freeze = function() { + this.$frozen = !0 + }, this.unfreeze = function() { + this.$frozen = !1 + }, this.$renderChanges = function(e, t) { + this.$changes && (e |= this.$changes, this.$changes = 0); + if (!this.session || !this.container.offsetWidth || this.$frozen || !e && !t) { + this.$changes |= e; + return + } + if (this.$size.$dirty) return this.$changes |= e, this.onResize(!0); + this.lineHeight || this.$textLayer.checkForSizeChanges(), this._signal("beforeRender"), this.session && this.session.$bidiHandler && this.session.$bidiHandler.updateCharacterWidths(this.$fontMetrics); + var n = this.layerConfig; + if (e & this.CHANGE_FULL || e & this.CHANGE_SIZE || e & this.CHANGE_TEXT || e & this.CHANGE_LINES || e & this.CHANGE_SCROLL || e & this.CHANGE_H_SCROLL) { + e |= this.$computeLayerConfig(); + if (n.firstRow != this.layerConfig.firstRow && n.firstRowScreen == this.layerConfig.firstRowScreen) { + var r = this.scrollTop + (n.firstRow - this.layerConfig.firstRow) * this.lineHeight; + r > 0 && (this.scrollTop = r, e |= this.CHANGE_SCROLL, e |= this.$computeLayerConfig()) + } + n = this.layerConfig, this.$updateScrollBarV(), e & this.CHANGE_H_SCROLL && this.$updateScrollBarH(), this.$gutterLayer.element.style.marginTop = -n.offset + "px", this.content.style.marginTop = -n.offset + "px", this.content.style.width = n.width + 2 * this.$padding + "px", this.content.style.height = n.minHeight + "px" + } + e & this.CHANGE_H_SCROLL && (this.content.style.marginLeft = -this.scrollLeft + "px", this.scroller.className = this.scrollLeft <= 0 ? "ace_scroller" : "ace_scroller ace_scroll-left"); + if (e & this.CHANGE_FULL) { + this.$textLayer.update(n), this.$showGutter && this.$gutterLayer.update(n), this.$markerBack.update(n), this.$markerFront.update(n), this.$cursorLayer.update(n), this.$moveTextAreaToCursor(), this.$highlightGutterLine && this.$updateGutterLineHighlight(), this._signal("afterRender"); + return + } + if (e & this.CHANGE_SCROLL) { + e & this.CHANGE_TEXT || e & this.CHANGE_LINES ? this.$textLayer.update(n) : this.$textLayer.scrollLines(n), this.$showGutter && this.$gutterLayer.update(n), this.$markerBack.update(n), this.$markerFront.update(n), this.$cursorLayer.update(n), this.$highlightGutterLine && this.$updateGutterLineHighlight(), this.$moveTextAreaToCursor(), this._signal("afterRender"); + return + } + e & this.CHANGE_TEXT ? (this.$textLayer.update(n), this.$showGutter && this.$gutterLayer.update(n)) : e & this.CHANGE_LINES ? (this.$updateLines() || e & this.CHANGE_GUTTER && this.$showGutter) && this.$gutterLayer.update(n) : (e & this.CHANGE_TEXT || e & this.CHANGE_GUTTER) && this.$showGutter && this.$gutterLayer.update(n), e & this.CHANGE_CURSOR && (this.$cursorLayer.update(n), this.$moveTextAreaToCursor(), this.$highlightGutterLine && this.$updateGutterLineHighlight()), e & (this.CHANGE_MARKER | this.CHANGE_MARKER_FRONT) && this.$markerFront.update(n), e & (this.CHANGE_MARKER | this.CHANGE_MARKER_BACK) && this.$markerBack.update(n), this._signal("afterRender") + }, this.$autosize = function() { + var e = this.session.getScreenLength() * this.lineHeight, + t = this.$maxLines * this.lineHeight, + n = Math.min(t, Math.max((this.$minLines || 1) * this.lineHeight, e)) + this.scrollMargin.v + (this.$extraHeight || 0); + this.$horizScroll && (n += this.scrollBarH.getHeight()), this.$maxPixelHeight && n > this.$maxPixelHeight && (n = this.$maxPixelHeight); + var r = e > t; + if (n != this.desiredHeight || this.$size.height != this.desiredHeight || r != this.$vScroll) { + r != this.$vScroll && (this.$vScroll = r, this.scrollBarV.setVisible(r)); + var i = this.container.clientWidth; + this.container.style.height = n + "px", this.$updateCachedSize(!0, this.$gutterWidth, i, n), this.desiredHeight = n, this._signal("autosize") + } + }, this.$computeLayerConfig = function() { + var e = this.session, + t = this.$size, + n = t.height <= 2 * this.lineHeight, + r = this.session.getScreenLength(), + i = r * this.lineHeight, + s = this.$getLongestLine(), + o = !n && (this.$hScrollBarAlwaysVisible || t.scrollerWidth - s - 2 * this.$padding < 0), + u = this.$horizScroll !== o; + u && (this.$horizScroll = o, this.scrollBarH.setVisible(o)); + var a = this.$vScroll; + this.$maxLines && this.lineHeight > 1 && this.$autosize(); + var f = this.scrollTop % this.lineHeight, + l = t.scrollerHeight + this.lineHeight, + c = !this.$maxLines && this.$scrollPastEnd ? (t.scrollerHeight - this.lineHeight) * this.$scrollPastEnd : 0; + i += c; + var h = this.scrollMargin; + this.session.setScrollTop(Math.max(-h.top, Math.min(this.scrollTop, i - t.scrollerHeight + h.bottom))), this.session.setScrollLeft(Math.max(-h.left, Math.min(this.scrollLeft, s + 2 * this.$padding - t.scrollerWidth + h.right))); + var p = !n && (this.$vScrollBarAlwaysVisible || t.scrollerHeight - i + c < 0 || this.scrollTop > h.top), + d = a !== p; + d && (this.$vScroll = p, this.scrollBarV.setVisible(p)); + var v = Math.ceil(l / this.lineHeight) - 1, + m = Math.max(0, Math.round((this.scrollTop - f) / this.lineHeight)), + g = m + v, + y, b, w = this.lineHeight; + m = e.screenToDocumentRow(m, 0); + var E = e.getFoldLine(m); + E && (m = E.start.row), y = e.documentToScreenRow(m, 0), b = e.getRowLength(m) * w, g = Math.min(e.screenToDocumentRow(g, 0), e.getLength() - 1), l = t.scrollerHeight + e.getRowLength(g) * w + b, f = this.scrollTop - y * w; + var S = 0; + this.layerConfig.width != s && (S = this.CHANGE_H_SCROLL); + if (u || d) S = this.$updateCachedSize(!0, this.gutterWidth, t.width, t.height), this._signal("scrollbarVisibilityChanged"), d && (s = this.$getLongestLine()); + return this.layerConfig = { + width: s, + padding: this.$padding, + firstRow: m, + firstRowScreen: y, + lastRow: g, + lineHeight: w, + characterWidth: this.characterWidth, + minHeight: l, + maxHeight: i, + offset: f, + gutterOffset: w ? Math.max(0, Math.ceil((f + t.height - t.scrollerHeight) / w)) : 0, + height: this.$size.scrollerHeight + }, S + }, this.$updateLines = function() { + if (!this.$changedLines) return; + var e = this.$changedLines.firstRow, + t = this.$changedLines.lastRow; + this.$changedLines = null; + var n = this.layerConfig; + if (e > n.lastRow + 1) return; + if (t < n.firstRow) return; + if (t === Infinity) { + this.$showGutter && this.$gutterLayer.update(n), this.$textLayer.update(n); + return + } + return this.$textLayer.updateLines(n, e, t), !0 + }, this.$getLongestLine = function() { + var e = this.session.getScreenWidth(); + return this.showInvisibles && !this.session.$useWrapMode && (e += 1), Math.max(this.$size.scrollerWidth - 2 * this.$padding, Math.round(e * this.characterWidth)) + }, this.updateFrontMarkers = function() { + this.$markerFront.setMarkers(this.session.getMarkers(!0)), this.$loop.schedule(this.CHANGE_MARKER_FRONT) + }, this.updateBackMarkers = function() { + this.$markerBack.setMarkers(this.session.getMarkers()), this.$loop.schedule(this.CHANGE_MARKER_BACK) + }, this.addGutterDecoration = function(e, t) { + this.$gutterLayer.addGutterDecoration(e, t) + }, this.removeGutterDecoration = function(e, t) { + this.$gutterLayer.removeGutterDecoration(e, t) + }, this.updateBreakpoints = function(e) { + this.$loop.schedule(this.CHANGE_GUTTER) + }, this.setAnnotations = function(e) { + this.$gutterLayer.setAnnotations(e), this.$loop.schedule(this.CHANGE_GUTTER) + }, this.updateCursor = function() { + this.$loop.schedule(this.CHANGE_CURSOR) + }, this.hideCursor = function() { + this.$cursorLayer.hideCursor() + }, this.showCursor = function() { + this.$cursorLayer.showCursor() + }, this.scrollSelectionIntoView = function(e, t, n) { + this.scrollCursorIntoView(e, n), this.scrollCursorIntoView(t, n) + }, this.scrollCursorIntoView = function(e, t, n) { + if (this.$size.scrollerHeight === 0) return; + var r = this.$cursorLayer.getPixelPosition(e), + i = r.left, + s = r.top, + o = n && n.top || 0, + u = n && n.bottom || 0, + a = this.$scrollAnimation ? this.session.getScrollTop() : this.scrollTop; + a + o > s ? (t && a + o > s + this.lineHeight && (s -= t * this.$size.scrollerHeight), s === 0 && (s = -this.scrollMargin.top), this.session.setScrollTop(s)) : a + this.$size.scrollerHeight - u < s + this.lineHeight && (t && a + this.$size.scrollerHeight - u < s - this.lineHeight && (s += t * this.$size.scrollerHeight), this.session.setScrollTop(s + this.lineHeight - this.$size.scrollerHeight)); + var f = this.scrollLeft; + f > i ? (i < this.$padding + 2 * this.layerConfig.characterWidth && (i = -this.scrollMargin.left), this.session.setScrollLeft(i)) : f + this.$size.scrollerWidth < i + this.characterWidth ? this.session.setScrollLeft(Math.round(i + this.characterWidth - this.$size.scrollerWidth)) : f <= this.$padding && i - f < this.characterWidth && this.session.setScrollLeft(0) + }, this.getScrollTop = function() { + return this.session.getScrollTop() + }, this.getScrollLeft = function() { + return this.session.getScrollLeft() + }, this.getScrollTopRow = function() { + return this.scrollTop / this.lineHeight + }, this.getScrollBottomRow = function() { + return Math.max(0, Math.floor((this.scrollTop + this.$size.scrollerHeight) / this.lineHeight) - 1) + }, this.scrollToRow = function(e) { + this.session.setScrollTop(e * this.lineHeight) + }, this.alignCursor = function(e, t) { + typeof e == "number" && (e = { + row: e, + column: 0 + }); + var n = this.$cursorLayer.getPixelPosition(e), + r = this.$size.scrollerHeight - this.lineHeight, + i = n.top - r * (t || 0); + return this.session.setScrollTop(i), i + }, this.STEPS = 8, this.$calcSteps = function(e, t) { + var n = 0, + r = this.STEPS, + i = [], + s = function(e, t, n) { + return n * (Math.pow(e - 1, 3) + 1) + t + }; + for (n = 0; n < r; ++n) i.push(s(n / this.STEPS, e, t - e)); + return i + }, this.scrollToLine = function(e, t, n, r) { + var i = this.$cursorLayer.getPixelPosition({ + row: e, + column: 0 + }), + s = i.top; + t && (s -= this.$size.scrollerHeight / 2); + var o = this.scrollTop; + this.session.setScrollTop(s), n !== !1 && this.animateScrolling(o, r) + }, this.animateScrolling = function(e, t) { + var n = this.scrollTop; + if (!this.$animatedScroll) return; + var r = this; + if (e == n) return; + if (this.$scrollAnimation) { + var i = this.$scrollAnimation.steps; + if (i.length) { + e = i[0]; + if (e == n) return + } + } + var s = r.$calcSteps(e, n); + this.$scrollAnimation = { + from: e, + to: n, + steps: s + }, clearInterval(this.$timer), r.session.setScrollTop(s.shift()), r.session.$scrollTop = n, this.$timer = setInterval(function() { + s.length ? (r.session.setScrollTop(s.shift()), r.session.$scrollTop = n) : n != null ? (r.session.$scrollTop = -1, r.session.setScrollTop(n), n = null) : (r.$timer = clearInterval(r.$timer), r.$scrollAnimation = null, t && t()) + }, 10) + }, this.scrollToY = function(e) { + this.scrollTop !== e && (this.$loop.schedule(this.CHANGE_SCROLL), this.scrollTop = e) + }, this.scrollToX = function(e) { + this.scrollLeft !== e && (this.scrollLeft = e), this.$loop.schedule(this.CHANGE_H_SCROLL) + }, this.scrollTo = function(e, t) { + this.session.setScrollTop(t), this.session.setScrollLeft(t) + }, this.scrollBy = function(e, t) { + t && this.session.setScrollTop(this.session.getScrollTop() + t), e && this.session.setScrollLeft(this.session.getScrollLeft() + e) + }, this.isScrollableBy = function(e, t) { + if (t < 0 && this.session.getScrollTop() >= 1 - this.scrollMargin.top) return !0; + if (t > 0 && this.session.getScrollTop() + this.$size.scrollerHeight - this.layerConfig.maxHeight < -1 + this.scrollMargin.bottom) return !0; + if (e < 0 && this.session.getScrollLeft() >= 1 - this.scrollMargin.left) return !0; + if (e > 0 && this.session.getScrollLeft() + this.$size.scrollerWidth - this.layerConfig.width < -1 + this.scrollMargin.right) return !0 + }, this.pixelToScreenCoordinates = function(e, t) { + var n = this.scroller.getBoundingClientRect(), + r = e + this.scrollLeft - n.left - this.$padding, + i = r / this.characterWidth, + s = Math.floor((t + this.scrollTop - n.top) / this.lineHeight), + o = Math.round(i); + return { + row: s, + column: o, + side: i - o > 0 ? 1 : -1, + offsetX: r + } + }, this.screenToTextCoordinates = function(e, t) { + var n = this.scroller.getBoundingClientRect(), + r = e + this.scrollLeft - n.left - this.$padding, + i = Math.round(r / this.characterWidth), + s = (t + this.scrollTop - n.top) / this.lineHeight; + return this.session.screenToDocumentPosition(s, Math.max(i, 0), r) + }, this.textToScreenCoordinates = function(e, t) { + var n = this.scroller.getBoundingClientRect(), + r = this.session.documentToScreenPosition(e, t), + i = this.$padding + (this.session.$bidiHandler.isBidiRow(r.row, e) ? this.session.$bidiHandler.getPosLeft(r.column) : Math.round(r.column * this.characterWidth)), + s = r.row * this.lineHeight; + return { + pageX: n.left + i - this.scrollLeft, + pageY: n.top + s - this.scrollTop + } + }, this.visualizeFocus = function() { + i.addCssClass(this.container, "ace_focus") + }, this.visualizeBlur = function() { + i.removeCssClass(this.container, "ace_focus") + }, this.showComposition = function(e) { + this.$composition || (this.$composition = { + keepTextAreaAtCursor: this.$keepTextAreaAtCursor, + cssText: this.textarea.style.cssText + }), this.$keepTextAreaAtCursor = !0, i.addCssClass(this.textarea, "ace_composition"), this.textarea.style.cssText = "", this.$moveTextAreaToCursor() + }, this.setCompositionText = function(e) { + this.$moveTextAreaToCursor() + }, this.hideComposition = function() { + if (!this.$composition) return; + i.removeCssClass(this.textarea, "ace_composition"), this.$keepTextAreaAtCursor = this.$composition.keepTextAreaAtCursor, this.textarea.style.cssText = this.$composition.cssText, this.$composition = null + }, this.setTheme = function(e, t) { + function o(r) { + if (n.$themeId != e) return t && t(); + if (!r || !r.cssClass) throw new Error("couldn't load module " + e + " or it didn't call define"); + i.importCssString(r.cssText, r.cssClass, n.container.ownerDocument), n.theme && i.removeCssClass(n.container, n.theme.cssClass); + var s = "padding" in r ? r.padding : "padding" in (n.theme || {}) ? 4 : n.$padding; + n.$padding && s != n.$padding && n.setPadding(s), n.$theme = r.cssClass, n.theme = r, i.addCssClass(n.container, r.cssClass), i.setCssClass(n.container, "ace_dark", r.isDark), n.$size && (n.$size.width = 0, n.$updateSizeAsync()), n._dispatchEvent("themeLoaded", { + theme: r + }), t && t() + } + var n = this; + this.$themeId = e, n._dispatchEvent("themeChange", { + theme: e + }); + if (!e || typeof e == "string") { + var r = e || this.$options.theme.initialValue; + s.loadModule(["theme", r], o) + } else o(e) + }, this.getTheme = function() { + return this.$themeId + }, this.setStyle = function(e, t) { + i.setCssClass(this.container, e, t !== !1) + }, this.unsetStyle = function(e) { + i.removeCssClass(this.container, e) + }, this.setCursorStyle = function(e) { + this.scroller.style.cursor != e && (this.scroller.style.cursor = e) + }, this.setMouseCursor = function(e) { + this.scroller.style.cursor = e + }, this.destroy = function() { + this.$textLayer.destroy(), this.$cursorLayer.destroy() + } + }).call(g.prototype), s.defineOptions(g.prototype, "renderer", { + animatedScroll: { + initialValue: !1 + }, + showInvisibles: { + set: function(e) { + this.$textLayer.setShowInvisibles(e) && this.$loop.schedule(this.CHANGE_TEXT) + }, + initialValue: !1 + }, + showPrintMargin: { + set: function() { + this.$updatePrintMargin() + }, + initialValue: !0 + }, + printMarginColumn: { + set: function() { + this.$updatePrintMargin() + }, + initialValue: 80 + }, + printMargin: { + set: function(e) { + typeof e == "number" && (this.$printMarginColumn = e), this.$showPrintMargin = !!e, this.$updatePrintMargin() + }, + get: function() { + return this.$showPrintMargin && this.$printMarginColumn + } + }, + showGutter: { + set: function(e) { + this.$gutter.style.display = e ? "block" : "none", this.$loop.schedule(this.CHANGE_FULL), this.onGutterResize() + }, + initialValue: !0 + }, + fadeFoldWidgets: { + set: function(e) { + i.setCssClass(this.$gutter, "ace_fade-fold-widgets", e) + }, + initialValue: !1 + }, + showFoldWidgets: { + set: function(e) { + this.$gutterLayer.setShowFoldWidgets(e) + }, + initialValue: !0 + }, + showLineNumbers: { + set: function(e) { + this.$gutterLayer.setShowLineNumbers(e), this.$loop.schedule(this.CHANGE_GUTTER) + }, + initialValue: !0 + }, + displayIndentGuides: { + set: function(e) { + this.$textLayer.setDisplayIndentGuides(e) && this.$loop.schedule(this.CHANGE_TEXT) + }, + initialValue: !0 + }, + highlightGutterLine: { + set: function(e) { + if (!this.$gutterLineHighlight) { + this.$gutterLineHighlight = i.createElement("div"), this.$gutterLineHighlight.className = "ace_gutter-active-line", this.$gutter.appendChild(this.$gutterLineHighlight); + return + } + this.$gutterLineHighlight.style.display = e ? "" : "none", this.$cursorLayer.$pixelPos && this.$updateGutterLineHighlight() + }, + initialValue: !1, + value: !0 + }, + hScrollBarAlwaysVisible: { + set: function(e) { + (!this.$hScrollBarAlwaysVisible || !this.$horizScroll) && this.$loop.schedule(this.CHANGE_SCROLL) + }, + initialValue: !1 + }, + vScrollBarAlwaysVisible: { + set: function(e) { + (!this.$vScrollBarAlwaysVisible || !this.$vScroll) && this.$loop.schedule(this.CHANGE_SCROLL) + }, + initialValue: !1 + }, + fontSize: { + set: function(e) { + typeof e == "number" && (e += "px"), this.container.style.fontSize = e, this.updateFontSize() + }, + initialValue: 12 + }, + fontFamily: { + set: function(e) { + this.container.style.fontFamily = e, this.updateFontSize() + } + }, + maxLines: { + set: function(e) { + this.updateFull() + } + }, + minLines: { + set: function(e) { + this.updateFull() + } + }, + maxPixelHeight: { + set: function(e) { + this.updateFull() + }, + initialValue: 0 + }, + scrollPastEnd: { + set: function(e) { + e = +e || 0; + if (this.$scrollPastEnd == e) return; + this.$scrollPastEnd = e, this.$loop.schedule(this.CHANGE_SCROLL) + }, + initialValue: 0, + handlesSet: !0 + }, + fixedWidthGutter: { + set: function(e) { + this.$gutterLayer.$fixedWidth = !!e, this.$loop.schedule(this.CHANGE_GUTTER) + } + }, + theme: { + set: function(e) { + this.setTheme(e) + }, + get: function() { + return this.$themeId || this.theme + }, + initialValue: "./theme/textmate", + handlesSet: !0 + } + }), t.VirtualRenderer = g +}), define("ace/worker/worker_client", ["require", "exports", "module", "ace/lib/oop", "ace/lib/net", "ace/lib/event_emitter", "ace/config"], function(e, t, n) { + "use strict"; + + function u(e) { + var t = "importScripts('" + i.qualifyURL(e) + "');"; + try { + return new Blob([t], { + type: "application/javascript" + }) + } catch (n) { + var r = window.BlobBuilder || window.WebKitBlobBuilder || window.MozBlobBuilder, + s = new r; + return s.append(t), s.getBlob("application/javascript") + } + } + + function a(e) { + var t = u(e), + n = window.URL || window.webkitURL, + r = n.createObjectURL(t); + return new Worker(r) + } + var r = e("../lib/oop"), + i = e("../lib/net"), + s = e("../lib/event_emitter").EventEmitter, + o = e("../config"), + f = function(t, n, r, i, s) { + this.$sendDeltaQueue = this.$sendDeltaQueue.bind(this), this.changeListener = this.changeListener.bind(this), this.onMessage = this.onMessage.bind(this), e.nameToUrl && !e.toUrl && (e.toUrl = e.nameToUrl); + if (o.get("packaged") || !e.toUrl) i = i || o.moduleUrl(n, "worker"); + else { + var u = this.$normalizePath; + i = i || u(e.toUrl("ace/worker/worker.js", null, "_")); + var f = {}; + t.forEach(function(t) { + f[t] = u(e.toUrl(t, null, "_").replace(/(\.js)?(\?.*)?$/, "")) + }) + } + this.$worker = a(i), s && this.send("importScripts", s), this.$worker.postMessage({ + init: !0, + tlns: f, + module: n, + classname: r + }), this.callbackId = 1, this.callbacks = {}, this.$worker.onmessage = this.onMessage + }; + (function() { + r.implement(this, s), this.onMessage = function(e) { + var t = e.data; + switch (t.type) { + case "event": + this._signal(t.name, { + data: t.data + }); + break; + case "call": + var n = this.callbacks[t.id]; + n && (n(t.data), delete this.callbacks[t.id]); + break; + case "error": + this.reportError(t.data); + break; + case "log": + window.console && console.log && console.log.apply(console, t.data) + } + }, this.reportError = function(e) { + window.console && console.error && console.error(e) + }, this.$normalizePath = function(e) { + return i.qualifyURL(e) + }, this.terminate = function() { + this._signal("terminate", {}), this.deltaQueue = null, this.$worker.terminate(), this.$worker = null, this.$doc && this.$doc.off("change", this.changeListener), this.$doc = null + }, this.send = function(e, t) { + this.$worker.postMessage({ + command: e, + args: t + }) + }, this.call = function(e, t, n) { + if (n) { + var r = this.callbackId++; + this.callbacks[r] = n, t.push(r) + } + this.send(e, t) + }, this.emit = function(e, t) { + try { + this.$worker.postMessage({ + event: e, + data: { + data: t.data + } + }) + } catch (n) { + console.error(n.stack) + } + }, this.attachToDocument = function(e) { + this.$doc && this.terminate(), this.$doc = e, this.call("setValue", [e.getValue()]), e.on("change", this.changeListener) + }, this.changeListener = function(e) { + this.deltaQueue || (this.deltaQueue = [], setTimeout(this.$sendDeltaQueue, 0)), e.action == "insert" ? this.deltaQueue.push(e.start, e.lines) : this.deltaQueue.push(e.start, e.end) + }, this.$sendDeltaQueue = function() { + var e = this.deltaQueue; + if (!e) return; + this.deltaQueue = null, e.length > 50 && e.length > this.$doc.getLength() >> 1 ? this.call("setValue", [this.$doc.getValue()]) : this.emit("change", { + data: e + }) + } + }).call(f.prototype); + var l = function(e, t, n) { + this.$sendDeltaQueue = this.$sendDeltaQueue.bind(this), this.changeListener = this.changeListener.bind(this), this.callbackId = 1, this.callbacks = {}, this.messageBuffer = []; + var r = null, + i = !1, + u = Object.create(s), + a = this; + this.$worker = {}, this.$worker.terminate = function() {}, this.$worker.postMessage = function(e) { + a.messageBuffer.push(e), r && (i ? setTimeout(f) : f()) + }, this.setEmitSync = function(e) { + i = e + }; + var f = function() { + var e = a.messageBuffer.shift(); + e.command ? r[e.command].apply(r, e.args) : e.event && u._signal(e.event, e.data) + }; + u.postMessage = function(e) { + a.onMessage({ + data: e + }) + }, u.callback = function(e, t) { + this.postMessage({ + type: "call", + id: t, + data: e + }) + }, u.emit = function(e, t) { + this.postMessage({ + type: "event", + name: e, + data: t + }) + }, o.loadModule(["worker", t], function(e) { + r = new e[n](u); + while (a.messageBuffer.length) f() + }) + }; + l.prototype = f.prototype, t.UIWorkerClient = l, t.WorkerClient = f, t.createWorker = a +}), define("ace/placeholder", ["require", "exports", "module", "ace/range", "ace/lib/event_emitter", "ace/lib/oop"], function(e, t, n) { + "use strict"; + var r = e("./range").Range, + i = e("./lib/event_emitter").EventEmitter, + s = e("./lib/oop"), + o = function(e, t, n, r, i, s) { + var o = this; + this.length = t, this.session = e, this.doc = e.getDocument(), this.mainClass = i, this.othersClass = s, this.$onUpdate = this.onUpdate.bind(this), this.doc.on("change", this.$onUpdate), this.$others = r, this.$onCursorChange = function() { + setTimeout(function() { + o.onCursorChange() + }) + }, this.$pos = n; + var u = e.getUndoManager().$undoStack || e.getUndoManager().$undostack || { + length: -1 + }; + this.$undoStackDepth = u.length, this.setup(), e.selection.on("changeCursor", this.$onCursorChange) + }; + (function() { + s.implement(this, i), this.setup = function() { + var e = this, + t = this.doc, + n = this.session; + this.selectionBefore = n.selection.toJSON(), n.selection.inMultiSelectMode && n.selection.toSingleRange(), this.pos = t.createAnchor(this.$pos.row, this.$pos.column); + var i = this.pos; + i.$insertRight = !0, i.detach(), i.markerId = n.addMarker(new r(i.row, i.column, i.row, i.column + this.length), this.mainClass, null, !1), this.others = [], this.$others.forEach(function(n) { + var r = t.createAnchor(n.row, n.column); + r.$insertRight = !0, r.detach(), e.others.push(r) + }), n.setUndoSelect(!1) + }, this.showOtherMarkers = function() { + if (this.othersActive) return; + var e = this.session, + t = this; + this.othersActive = !0, this.others.forEach(function(n) { + n.markerId = e.addMarker(new r(n.row, n.column, n.row, n.column + t.length), t.othersClass, null, !1) + }) + }, this.hideOtherMarkers = function() { + if (!this.othersActive) return; + this.othersActive = !1; + for (var e = 0; e < this.others.length; e++) this.session.removeMarker(this.others[e].markerId) + }, this.onUpdate = function(e) { + if (this.$updating) return this.updateAnchors(e); + var t = e; + if (t.start.row !== t.end.row) return; + if (t.start.row !== this.pos.row) return; + this.$updating = !0; + var n = e.action === "insert" ? t.end.column - t.start.column : t.start.column - t.end.column, + i = t.start.column >= this.pos.column && t.start.column <= this.pos.column + this.length + 1, + s = t.start.column - this.pos.column; + this.updateAnchors(e), i && (this.length += n); + if (i && !this.session.$fromUndo) + if (e.action === "insert") + for (var o = this.others.length - 1; o >= 0; o--) { + var u = this.others[o], + a = { + row: u.row, + column: u.column + s + }; + this.doc.insertMergedLines(a, e.lines) + } else if (e.action === "remove") + for (var o = this.others.length - 1; o >= 0; o--) { + var u = this.others[o], + a = { + row: u.row, + column: u.column + s + }; + this.doc.remove(new r(a.row, a.column, a.row, a.column - n)) + } + this.$updating = !1, this.updateMarkers() + }, this.updateAnchors = function(e) { + this.pos.onChange(e); + for (var t = this.others.length; t--;) this.others[t].onChange(e); + this.updateMarkers() + }, this.updateMarkers = function() { + if (this.$updating) return; + var e = this, + t = this.session, + n = function(n, i) { + t.removeMarker(n.markerId), n.markerId = t.addMarker(new r(n.row, n.column, n.row, n.column + e.length), i, null, !1) + }; + n(this.pos, this.mainClass); + for (var i = this.others.length; i--;) n(this.others[i], this.othersClass) + }, this.onCursorChange = function(e) { + if (this.$updating || !this.session) return; + var t = this.session.selection.getCursor(); + t.row === this.pos.row && t.column >= this.pos.column && t.column <= this.pos.column + this.length ? (this.showOtherMarkers(), this._emit("cursorEnter", e)) : (this.hideOtherMarkers(), this._emit("cursorLeave", e)) + }, this.detach = function() { + this.session.removeMarker(this.pos && this.pos.markerId), this.hideOtherMarkers(), this.doc.removeEventListener("change", this.$onUpdate), this.session.selection.removeEventListener("changeCursor", this.$onCursorChange), this.session.setUndoSelect(!0), this.session = null + }, this.cancel = function() { + if (this.$undoStackDepth === -1) return; + var e = this.session.getUndoManager(), + t = (e.$undoStack || e.$undostack).length - this.$undoStackDepth; + for (var n = 0; n < t; n++) e.undo(!0); + this.selectionBefore && this.session.selection.fromJSON(this.selectionBefore) + } + }).call(o.prototype), t.PlaceHolder = o +}), define("ace/mouse/multi_select_handler", ["require", "exports", "module", "ace/lib/event", "ace/lib/useragent"], function(e, t, n) { + function s(e, t) { + return e.row == t.row && e.column == t.column + } + + function o(e) { + var t = e.domEvent, + n = t.altKey, + o = t.shiftKey, + u = t.ctrlKey, + a = e.getAccelKey(), + f = e.getButton(); + u && i.isMac && (f = t.button); + if (e.editor.inMultiSelectMode && f == 2) { + e.editor.textInput.onContextMenu(e.domEvent); + return + } + if (!u && !n && !a) { + f === 0 && e.editor.inMultiSelectMode && e.editor.exitMultiSelectMode(); + return + } + if (f !== 0) return; + var l = e.editor, + c = l.selection, + h = l.inMultiSelectMode, + p = e.getDocumentPosition(), + d = c.getCursor(), + v = e.inSelection() || c.isEmpty() && s(p, d), + m = e.x, + g = e.y, + y = function(e) { + m = e.clientX, g = e.clientY + }, + b = l.session, + w = l.renderer.pixelToScreenCoordinates(m, g), + E = w, + S; + if (l.$mouseHandler.$enableJumpToDef) u && n || a && n ? S = o ? "block" : "add" : n && l.$blockSelectEnabled && (S = "block"); + else if (a && !n) { + S = "add"; + if (!h && o) return + } else n && l.$blockSelectEnabled && (S = "block"); + S && i.isMac && t.ctrlKey && l.$mouseHandler.cancelContextMenu(); + if (S == "add") { + if (!h && v) return; + if (!h) { + var x = c.toOrientedRange(); + l.addSelectionMarker(x) + } + var T = c.rangeList.rangeAtPoint(p); + l.$blockScrolling++, l.inVirtualSelectionMode = !0, o && (T = null, x = c.ranges[0] || x, l.removeSelectionMarker(x)), l.once("mouseup", function() { + var e = c.toOrientedRange(); + T && e.isEmpty() && s(T.cursor, e.cursor) ? c.substractPoint(e.cursor) : (o ? c.substractPoint(x.cursor) : x && (l.removeSelectionMarker(x), c.addRange(x)), c.addRange(e)), l.$blockScrolling--, l.inVirtualSelectionMode = !1 + }) + } else if (S == "block") { + e.stop(), l.inVirtualSelectionMode = !0; + var N, C = [], + k = function() { + var e = l.renderer.pixelToScreenCoordinates(m, g), + t = b.screenToDocumentPosition(e.row, e.column, e.offsetX); + if (s(E, e) && s(t, c.lead)) return; + E = e, l.$blockScrolling++, l.selection.moveToPosition(t), l.renderer.scrollCursorIntoView(), l.removeSelectionMarkers(C), C = c.rectangularRangeBlock(E, w), l.$mouseHandler.$clickSelection && C.length == 1 && C[0].isEmpty() && (C[0] = l.$mouseHandler.$clickSelection.clone()), C.forEach(l.addSelectionMarker, l), l.updateSelectionMarkers(), l.$blockScrolling-- + }; + l.$blockScrolling++, h && !a ? c.toSingleRange() : !h && a && (N = c.toOrientedRange(), l.addSelectionMarker(N)), o ? w = b.documentToScreenPosition(c.lead) : c.moveToPosition(p), l.$blockScrolling--, E = { + row: -1, + column: -1 + }; + var L = function(e) { + clearInterval(O), l.removeSelectionMarkers(C), C.length || (C = [c.toOrientedRange()]), l.$blockScrolling++, N && (l.removeSelectionMarker(N), c.toSingleRange(N)); + for (var t = 0; t < C.length; t++) c.addRange(C[t]); + l.inVirtualSelectionMode = !1, l.$mouseHandler.$clickSelection = null, l.$blockScrolling-- + }, + A = k; + r.capture(l.container, y, L); + var O = setInterval(function() { + A() + }, 20); + return e.preventDefault() + } + } + var r = e("../lib/event"), + i = e("../lib/useragent"); + t.onMouseDown = o +}), define("ace/commands/multi_select_commands", ["require", "exports", "module", "ace/keyboard/hash_handler"], function(e, t, n) { + t.defaultCommands = [{ + name: "addCursorAbove", + exec: function(e) { + e.selectMoreLines(-1) + }, + bindKey: { + win: "Ctrl-Alt-Up", + mac: "Ctrl-Alt-Up" + }, + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "addCursorBelow", + exec: function(e) { + e.selectMoreLines(1) + }, + bindKey: { + win: "Ctrl-Alt-Down", + mac: "Ctrl-Alt-Down" + }, + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "addCursorAboveSkipCurrent", + exec: function(e) { + e.selectMoreLines(-1, !0) + }, + bindKey: { + win: "Ctrl-Alt-Shift-Up", + mac: "Ctrl-Alt-Shift-Up" + }, + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "addCursorBelowSkipCurrent", + exec: function(e) { + e.selectMoreLines(1, !0) + }, + bindKey: { + win: "Ctrl-Alt-Shift-Down", + mac: "Ctrl-Alt-Shift-Down" + }, + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selectMoreBefore", + exec: function(e) { + e.selectMore(-1) + }, + bindKey: { + win: "Ctrl-Alt-Left", + mac: "Ctrl-Alt-Left" + }, + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selectMoreAfter", + exec: function(e) { + e.selectMore(1) + }, + bindKey: { + win: "Ctrl-Alt-Right", + mac: "Ctrl-Alt-Right" + }, + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selectNextBefore", + exec: function(e) { + e.selectMore(-1, !0) + }, + bindKey: { + win: "Ctrl-Alt-Shift-Left", + mac: "Ctrl-Alt-Shift-Left" + }, + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "selectNextAfter", + exec: function(e) { + e.selectMore(1, !0) + }, + bindKey: { + win: "Ctrl-Alt-Shift-Right", + mac: "Ctrl-Alt-Shift-Right" + }, + scrollIntoView: "cursor", + readOnly: !0 + }, { + name: "splitIntoLines", + exec: function(e) { + e.multiSelect.splitIntoLines() + }, + bindKey: { + win: "Ctrl-Alt-L", + mac: "Ctrl-Alt-L" + }, + readOnly: !0 + }, { + name: "alignCursors", + exec: function(e) { + e.alignCursors() + }, + bindKey: { + win: "Ctrl-Alt-A", + mac: "Ctrl-Alt-A" + }, + scrollIntoView: "cursor" + }, { + name: "findAll", + exec: function(e) { + e.findAll() + }, + bindKey: { + win: "Ctrl-Alt-K", + mac: "Ctrl-Alt-G" + }, + scrollIntoView: "cursor", + readOnly: !0 + }], t.multiSelectCommands = [{ + name: "singleSelection", + bindKey: "esc", + exec: function(e) { + e.exitMultiSelectMode() + }, + scrollIntoView: "cursor", + readOnly: !0, + isAvailable: function(e) { + return e && e.inMultiSelectMode + } + }]; + var r = e("../keyboard/hash_handler").HashHandler; + t.keyboardHandler = new r(t.multiSelectCommands) +}), define("ace/multi_select", ["require", "exports", "module", "ace/range_list", "ace/range", "ace/selection", "ace/mouse/multi_select_handler", "ace/lib/event", "ace/lib/lang", "ace/commands/multi_select_commands", "ace/search", "ace/edit_session", "ace/editor", "ace/config"], function(e, t, n) { + function h(e, t, n) { + return c.$options.wrap = !0, c.$options.needle = t, c.$options.backwards = n == -1, c.find(e) + } + + function v(e, t) { + return e.row == t.row && e.column == t.column + } + + function m(e) { + if (e.$multiselectOnSessionChange) return; + e.$onAddRange = e.$onAddRange.bind(e), e.$onRemoveRange = e.$onRemoveRange.bind(e), e.$onMultiSelect = e.$onMultiSelect.bind(e), e.$onSingleSelect = e.$onSingleSelect.bind(e), e.$multiselectOnSessionChange = t.onSessionChange.bind(e), e.$checkMultiselectChange = e.$checkMultiselectChange.bind(e), e.$multiselectOnSessionChange(e), e.on("changeSession", e.$multiselectOnSessionChange), e.on("mousedown", o), e.commands.addCommands(f.defaultCommands), g(e) + } + + function g(e) { + function r(t) { + n && (e.renderer.setMouseCursor(""), n = !1) + } + var t = e.textInput.getElement(), + n = !1; + u.addListener(t, "keydown", function(t) { + var i = t.keyCode == 18 && !(t.ctrlKey || t.shiftKey || t.metaKey); + e.$blockSelectEnabled && i ? n || (e.renderer.setMouseCursor("crosshair"), n = !0) : n && r() + }), u.addListener(t, "keyup", r), u.addListener(t, "blur", r) + } + var r = e("./range_list").RangeList, + i = e("./range").Range, + s = e("./selection").Selection, + o = e("./mouse/multi_select_handler").onMouseDown, + u = e("./lib/event"), + a = e("./lib/lang"), + f = e("./commands/multi_select_commands"); + t.commands = f.defaultCommands.concat(f.multiSelectCommands); + var l = e("./search").Search, + c = new l, + p = e("./edit_session").EditSession; + (function() { + this.getSelectionMarkers = function() { + return this.$selectionMarkers + } + }).call(p.prototype), + function() { + this.ranges = null, this.rangeList = null, this.addRange = function(e, t) { + if (!e) return; + if (!this.inMultiSelectMode && this.rangeCount === 0) { + var n = this.toOrientedRange(); + this.rangeList.add(n), this.rangeList.add(e); + if (this.rangeList.ranges.length != 2) return this.rangeList.removeAll(), t || this.fromOrientedRange(e); + this.rangeList.removeAll(), this.rangeList.add(n), this.$onAddRange(n) + } + e.cursor || (e.cursor = e.end); + var r = this.rangeList.add(e); + return this.$onAddRange(e), r.length && this.$onRemoveRange(r), this.rangeCount > 1 && !this.inMultiSelectMode && (this._signal("multiSelect"), this.inMultiSelectMode = !0, this.session.$undoSelect = !1, this.rangeList.attach(this.session)), t || this.fromOrientedRange(e) + }, this.toSingleRange = function(e) { + e = e || this.ranges[0]; + var t = this.rangeList.removeAll(); + t.length && this.$onRemoveRange(t), e && this.fromOrientedRange(e) + }, this.substractPoint = function(e) { + var t = this.rangeList.substractPoint(e); + if (t) return this.$onRemoveRange(t), t[0] + }, this.mergeOverlappingRanges = function() { + var e = this.rangeList.merge(); + e.length ? this.$onRemoveRange(e) : this.ranges[0] && this.fromOrientedRange(this.ranges[0]) + }, this.$onAddRange = function(e) { + this.rangeCount = this.rangeList.ranges.length, this.ranges.unshift(e), this._signal("addRange", { + range: e + }) + }, this.$onRemoveRange = function(e) { + this.rangeCount = this.rangeList.ranges.length; + if (this.rangeCount == 1 && this.inMultiSelectMode) { + var t = this.rangeList.ranges.pop(); + e.push(t), this.rangeCount = 0 + } + for (var n = e.length; n--;) { + var r = this.ranges.indexOf(e[n]); + this.ranges.splice(r, 1) + } + this._signal("removeRange", { + ranges: e + }), this.rangeCount === 0 && this.inMultiSelectMode && (this.inMultiSelectMode = !1, this._signal("singleSelect"), this.session.$undoSelect = !0, this.rangeList.detach(this.session)), t = t || this.ranges[0], t && !t.isEqual(this.getRange()) && this.fromOrientedRange(t) + }, this.$initRangeList = function() { + if (this.rangeList) return; + this.rangeList = new r, this.ranges = [], this.rangeCount = 0 + }, this.getAllRanges = function() { + return this.rangeCount ? this.rangeList.ranges.concat() : [this.getRange()] + }, this.splitIntoLines = function() { + if (this.rangeCount > 1) { + var e = this.rangeList.ranges, + t = e[e.length - 1], + n = i.fromPoints(e[0].start, t.end); + this.toSingleRange(), this.setSelectionRange(n, t.cursor == t.start) + } else { + var n = this.getRange(), + r = this.isBackwards(), + s = n.start.row, + o = n.end.row; + if (s == o) { + if (r) var u = n.end, + a = n.start; + else var u = n.start, + a = n.end; + this.addRange(i.fromPoints(a, a)), this.addRange(i.fromPoints(u, u)); + return + } + var f = [], + l = this.getLineRange(s, !0); + l.start.column = n.start.column, f.push(l); + for (var c = s + 1; c < o; c++) f.push(this.getLineRange(c, !0)); + l = this.getLineRange(o, !0), l.end.column = n.end.column, f.push(l), f.forEach(this.addRange, this) + } + }, this.toggleBlockSelection = function() { + if (this.rangeCount > 1) { + var e = this.rangeList.ranges, + t = e[e.length - 1], + n = i.fromPoints(e[0].start, t.end); + this.toSingleRange(), this.setSelectionRange(n, t.cursor == t.start) + } else { + var r = this.session.documentToScreenPosition(this.selectionLead), + s = this.session.documentToScreenPosition(this.selectionAnchor), + o = this.rectangularRangeBlock(r, s); + o.forEach(this.addRange, this) + } + }, this.rectangularRangeBlock = function(e, t, n) { + var r = [], + s = e.column < t.column; + if (s) var o = e.column, + u = t.column, + a = e.offsetX, + f = t.offsetX; + else var o = t.column, + u = e.column, + a = t.offsetX, + f = e.offsetX; + var l = e.row < t.row; + if (l) var c = e.row, + h = t.row; + else var c = t.row, + h = e.row; + o < 0 && (o = 0), c < 0 && (c = 0), c == h && (n = !0); + for (var p = c; p <= h; p++) { + var d = i.fromPoints(this.session.screenToDocumentPosition(p, o, a), this.session.screenToDocumentPosition(p, u, f)); + if (d.isEmpty()) { + if (m && v(d.end, m)) break; + var m = d.end + } + d.cursor = s ? d.start : d.end, r.push(d) + } + l && r.reverse(); + if (!n) { + var g = r.length - 1; + while (r[g].isEmpty() && g > 0) g--; + if (g > 0) { + var y = 0; + while (r[y].isEmpty()) y++ + } + for (var b = g; b >= y; b--) r[b].isEmpty() && r.splice(b, 1) + } + return r + } + }.call(s.prototype); + var d = e("./editor").Editor; + (function() { + this.updateSelectionMarkers = function() { + this.renderer.updateCursor(), this.renderer.updateBackMarkers() + }, this.addSelectionMarker = function(e) { + e.cursor || (e.cursor = e.end); + var t = this.getSelectionStyle(); + return e.marker = this.session.addMarker(e, "ace_selection", t), this.session.$selectionMarkers.push(e), this.session.selectionMarkerCount = this.session.$selectionMarkers.length, e + }, this.removeSelectionMarker = function(e) { + if (!e.marker) return; + this.session.removeMarker(e.marker); + var t = this.session.$selectionMarkers.indexOf(e); + t != -1 && this.session.$selectionMarkers.splice(t, 1), this.session.selectionMarkerCount = this.session.$selectionMarkers.length + }, this.removeSelectionMarkers = function(e) { + var t = this.session.$selectionMarkers; + for (var n = e.length; n--;) { + var r = e[n]; + if (!r.marker) continue; + this.session.removeMarker(r.marker); + var i = t.indexOf(r); + i != -1 && t.splice(i, 1) + } + this.session.selectionMarkerCount = t.length + }, this.$onAddRange = function(e) { + this.addSelectionMarker(e.range), this.renderer.updateCursor(), this.renderer.updateBackMarkers() + }, this.$onRemoveRange = function(e) { + this.removeSelectionMarkers(e.ranges), this.renderer.updateCursor(), this.renderer.updateBackMarkers() + }, this.$onMultiSelect = function(e) { + if (this.inMultiSelectMode) return; + this.inMultiSelectMode = !0, this.setStyle("ace_multiselect"), this.keyBinding.addKeyboardHandler(f.keyboardHandler), this.commands.setDefaultHandler("exec", this.$onMultiSelectExec), this.renderer.updateCursor(), this.renderer.updateBackMarkers() + }, this.$onSingleSelect = function(e) { + if (this.session.multiSelect.inVirtualMode) return; + this.inMultiSelectMode = !1, this.unsetStyle("ace_multiselect"), this.keyBinding.removeKeyboardHandler(f.keyboardHandler), this.commands.removeDefaultHandler("exec", this.$onMultiSelectExec), this.renderer.updateCursor(), this.renderer.updateBackMarkers(), this._emit("changeSelection") + }, this.$onMultiSelectExec = function(e) { + var t = e.command, + n = e.editor; + if (!n.multiSelect) return; + if (!t.multiSelectAction) { + var r = t.exec(n, e.args || {}); + n.multiSelect.addRange(n.multiSelect.toOrientedRange()), n.multiSelect.mergeOverlappingRanges() + } else t.multiSelectAction == "forEach" ? r = n.forEachSelection(t, e.args) : t.multiSelectAction == "forEachLine" ? r = n.forEachSelection(t, e.args, !0) : t.multiSelectAction == "single" ? (n.exitMultiSelectMode(), r = t.exec(n, e.args || {})) : r = t.multiSelectAction(n, e.args || {}); + return r + }, this.forEachSelection = function(e, t, n) { + if (this.inVirtualSelectionMode) return; + var r = n && n.keepOrder, + i = n == 1 || n && n.$byLines, + o = this.session, + u = this.selection, + a = u.rangeList, + f = (r ? u : a).ranges, + l; + if (!f.length) return e.exec ? e.exec(this, t || {}) : e(this, t || {}); + var c = u._eventRegistry; + u._eventRegistry = {}; + var h = new s(o); + this.inVirtualSelectionMode = !0; + for (var p = f.length; p--;) { + if (i) + while (p > 0 && f[p].start.row == f[p - 1].end.row) p--; + h.fromOrientedRange(f[p]), h.index = p, this.selection = o.selection = h; + var d = e.exec ? e.exec(this, t || {}) : e(this, t || {}); + !l && d !== undefined && (l = d), h.toOrientedRange(f[p]) + } + h.detach(), this.selection = o.selection = u, this.inVirtualSelectionMode = !1, u._eventRegistry = c, u.mergeOverlappingRanges(); + var v = this.renderer.$scrollAnimation; + return this.onCursorChange(), this.onSelectionChange(), v && v.from == v.to && this.renderer.animateScrolling(v.from), l + }, this.exitMultiSelectMode = function() { + if (!this.inMultiSelectMode || this.inVirtualSelectionMode) return; + this.multiSelect.toSingleRange() + }, this.getSelectedText = function() { + var e = ""; + if (this.inMultiSelectMode && !this.inVirtualSelectionMode) { + var t = this.multiSelect.rangeList.ranges, + n = []; + for (var r = 0; r < t.length; r++) n.push(this.session.getTextRange(t[r])); + var i = this.session.getDocument().getNewLineCharacter(); + e = n.join(i), e.length == (n.length - 1) * i.length && (e = "") + } else this.selection.isEmpty() || (e = this.session.getTextRange(this.getSelectionRange())); + return e + }, this.$checkMultiselectChange = function(e, t) { + if (this.inMultiSelectMode && !this.inVirtualSelectionMode) { + var n = this.multiSelect.ranges[0]; + if (this.multiSelect.isEmpty() && t == this.multiSelect.anchor) return; + var r = t == this.multiSelect.anchor ? n.cursor == n.start ? n.end : n.start : n.cursor; + (r.row != t.row || this.session.$clipPositionToDocument(r.row, r.column).column != t.column) && this.multiSelect.toSingleRange(this.multiSelect.toOrientedRange()) + } + }, this.findAll = function(e, t, n) { + t = t || {}, t.needle = e || t.needle; + if (t.needle == undefined) { + var r = this.selection.isEmpty() ? this.selection.getWordRange() : this.selection.getRange(); + t.needle = this.session.getTextRange(r) + } + this.$search.set(t); + var i = this.$search.findAll(this.session); + if (!i.length) return 0; + this.$blockScrolling += 1; + var s = this.multiSelect; + n || s.toSingleRange(i[0]); + for (var o = i.length; o--;) s.addRange(i[o], !0); + return r && s.rangeList.rangeAtPoint(r.start) && s.addRange(r, !0), this.$blockScrolling -= 1, i.length + }, this.selectMoreLines = function(e, t) { + var n = this.selection.toOrientedRange(), + r = n.cursor == n.end, + s = this.session.documentToScreenPosition(n.cursor); + this.selection.$desiredColumn && (s.column = this.selection.$desiredColumn); + var o = this.session.screenToDocumentPosition(s.row + e, s.column); + if (!n.isEmpty()) var u = this.session.documentToScreenPosition(r ? n.end : n.start), + a = this.session.screenToDocumentPosition(u.row + e, u.column); + else var a = o; + if (r) { + var f = i.fromPoints(o, a); + f.cursor = f.start + } else { + var f = i.fromPoints(a, o); + f.cursor = f.end + } + f.desiredColumn = s.column; + if (!this.selection.inMultiSelectMode) this.selection.addRange(n); + else if (t) var l = n.cursor; + this.selection.addRange(f), l && this.selection.substractPoint(l) + }, this.transposeSelections = function(e) { + var t = this.session, + n = t.multiSelect, + r = n.ranges; + for (var i = r.length; i--;) { + var s = r[i]; + if (s.isEmpty()) { + var o = t.getWordRange(s.start.row, s.start.column); + s.start.row = o.start.row, s.start.column = o.start.column, s.end.row = o.end.row, s.end.column = o.end.column + } + } + n.mergeOverlappingRanges(); + var u = []; + for (var i = r.length; i--;) { + var s = r[i]; + u.unshift(t.getTextRange(s)) + } + e < 0 ? u.unshift(u.pop()) : u.push(u.shift()); + for (var i = r.length; i--;) { + var s = r[i], + o = s.clone(); + t.replace(s, u[i]), s.start.row = o.start.row, s.start.column = o.start.column + } + }, this.selectMore = function(e, t, n) { + var r = this.session, + i = r.multiSelect, + s = i.toOrientedRange(); + if (s.isEmpty()) { + s = r.getWordRange(s.start.row, s.start.column), s.cursor = e == -1 ? s.start : s.end, this.multiSelect.addRange(s); + if (n) return + } + var o = r.getTextRange(s), + u = h(r, o, e); + u && (u.cursor = e == -1 ? u.start : u.end, this.$blockScrolling += 1, this.session.unfold(u), this.multiSelect.addRange(u), this.$blockScrolling -= 1, this.renderer.scrollCursorIntoView(null, .5)), t && this.multiSelect.substractPoint(s.cursor) + }, this.alignCursors = function() { + var e = this.session, + t = e.multiSelect, + n = t.ranges, + r = -1, + s = n.filter(function(e) { + if (e.cursor.row == r) return !0; + r = e.cursor.row + }); + if (!n.length || s.length == n.length - 1) { + var o = this.selection.getRange(), + u = o.start.row, + f = o.end.row, + l = u == f; + if (l) { + var c = this.session.getLength(), + h; + do h = this.session.getLine(f); while (/[=:]/.test(h) && ++f < c); + do h = this.session.getLine(u); while (/[=:]/.test(h) && --u > 0); + u < 0 && (u = 0), f >= c && (f = c - 1) + } + var p = this.session.removeFullLines(u, f); + p = this.$reAlignText(p, l), this.session.insert({ + row: u, + column: 0 + }, p.join("\n") + "\n"), l || (o.start.column = 0, o.end.column = p[p.length - 1].length), this.selection.setRange(o) + } else { + s.forEach(function(e) { + t.substractPoint(e.cursor) + }); + var d = 0, + v = Infinity, + m = n.map(function(t) { + var n = t.cursor, + r = e.getLine(n.row), + i = r.substr(n.column).search(/\S/g); + return i == -1 && (i = 0), n.column > d && (d = n.column), i < v && (v = i), i + }); + n.forEach(function(t, n) { + var r = t.cursor, + s = d - r.column, + o = m[n] - v; + s > o ? e.insert(r, a.stringRepeat(" ", s - o)) : e.remove(new i(r.row, r.column, r.row, r.column - s + o)), t.start.column = t.end.column = d, t.start.row = t.end.row = r.row, t.cursor = t.end + }), t.fromOrientedRange(n[0]), this.renderer.updateCursor(), this.renderer.updateBackMarkers() + } + }, this.$reAlignText = function(e, t) { + function u(e) { + return a.stringRepeat(" ", e) + } + + function f(e) { + return e[2] ? u(i) + e[2] + u(s - e[2].length + o) + e[4].replace(/^([=:])\s+/, "$1 ") : e[0] + } + + function l(e) { + return e[2] ? u(i + s - e[2].length) + e[2] + u(o, " ") + e[4].replace(/^([=:])\s+/, "$1 ") : e[0] + } + + function c(e) { + return e[2] ? u(i) + e[2] + u(o) + e[4].replace(/^([=:])\s+/, "$1 ") : e[0] + } + var n = !0, + r = !0, + i, s, o; + return e.map(function(e) { + var t = e.match(/(\s*)(.*?)(\s*)([=:].*)/); + return t ? i == null ? (i = t[1].length, s = t[2].length, o = t[3].length, t) : (i + s + o != t[1].length + t[2].length + t[3].length && (r = !1), i != t[1].length && (n = !1), i > t[1].length && (i = t[1].length), s < t[2].length && (s = t[2].length), o > t[3].length && (o = t[3].length), t) : [e] + }).map(t ? f : n ? r ? l : f : c) + } + }).call(d.prototype), t.onSessionChange = function(e) { + var t = e.session; + t && !t.multiSelect && (t.$selectionMarkers = [], t.selection.$initRangeList(), t.multiSelect = t.selection), this.multiSelect = t && t.multiSelect; + var n = e.oldSession; + n && (n.multiSelect.off("addRange", this.$onAddRange), n.multiSelect.off("removeRange", this.$onRemoveRange), n.multiSelect.off("multiSelect", this.$onMultiSelect), n.multiSelect.off("singleSelect", this.$onSingleSelect), n.multiSelect.lead.off("change", this.$checkMultiselectChange), n.multiSelect.anchor.off("change", this.$checkMultiselectChange)), t && (t.multiSelect.on("addRange", this.$onAddRange), t.multiSelect.on("removeRange", this.$onRemoveRange), t.multiSelect.on("multiSelect", this.$onMultiSelect), t.multiSelect.on("singleSelect", this.$onSingleSelect), t.multiSelect.lead.on("change", this.$checkMultiselectChange), t.multiSelect.anchor.on("change", this.$checkMultiselectChange)), t && this.inMultiSelectMode != t.selection.inMultiSelectMode && (t.selection.inMultiSelectMode ? this.$onMultiSelect() : this.$onSingleSelect()) + }, t.MultiSelect = m, e("./config").defineOptions(d.prototype, "editor", { + enableMultiselect: { + set: function(e) { + m(this), e ? (this.on("changeSession", this.$multiselectOnSessionChange), this.on("mousedown", o)) : (this.off("changeSession", this.$multiselectOnSessionChange), this.off("mousedown", o)) + }, + value: !0 + }, + enableBlockSelect: { + set: function(e) { + this.$blockSelectEnabled = e + }, + value: !0 + } + }) +}), define("ace/mode/folding/fold_mode", ["require", "exports", "module", "ace/range"], function(e, t, n) { + "use strict"; + var r = e("../../range").Range, + i = t.FoldMode = function() {}; + (function() { + this.foldingStartMarker = null, this.foldingStopMarker = null, this.getFoldWidget = function(e, t, n) { + var r = e.getLine(n); + return this.foldingStartMarker.test(r) ? "start" : t == "markbeginend" && this.foldingStopMarker && this.foldingStopMarker.test(r) ? "end" : "" + }, this.getFoldWidgetRange = function(e, t, n) { + return null + }, this.indentationBlock = function(e, t, n) { + var i = /\S/, + s = e.getLine(t), + o = s.search(i); + if (o == -1) return; + var u = n || s.length, + a = e.getLength(), + f = t, + l = t; + while (++t < a) { + var c = e.getLine(t).search(i); + if (c == -1) continue; + if (c <= o) break; + l = t + } + if (l > f) { + var h = e.getLine(l).length; + return new r(f, u, l, h) + } + }, this.openingBracketBlock = function(e, t, n, i, s) { + var o = { + row: n, + column: i + 1 + }, + u = e.$findClosingBracket(t, o, s); + if (!u) return; + var a = e.foldWidgets[u.row]; + return a == null && (a = e.getFoldWidget(u.row)), a == "start" && u.row > o.row && (u.row--, u.column = e.getLine(u.row).length), r.fromPoints(o, u) + }, this.closingBracketBlock = function(e, t, n, i, s) { + var o = { + row: n, + column: i + }, + u = e.$findOpeningBracket(t, o); + if (!u) return; + return u.column++, o.column--, r.fromPoints(u, o) + } + }).call(i.prototype) +}), define("ace/theme/textmate", ["require", "exports", "module", "ace/lib/dom"], function(e, t, n) { + "use strict"; + t.isDark = !1, t.cssClass = "ace-tm", t.cssText = '.ace-tm .ace_gutter {background: #f0f0f0;color: #333;}.ace-tm .ace_print-margin {width: 1px;background: #e8e8e8;}.ace-tm .ace_fold {background-color: #6B72E6;}.ace-tm {background-color: #FFFFFF;color: black;}.ace-tm .ace_cursor {color: black;}.ace-tm .ace_invisible {color: rgb(191, 191, 191);}.ace-tm .ace_storage,.ace-tm .ace_keyword {color: blue;}.ace-tm .ace_constant {color: rgb(197, 6, 11);}.ace-tm .ace_constant.ace_buildin {color: rgb(88, 72, 246);}.ace-tm .ace_constant.ace_language {color: rgb(88, 92, 246);}.ace-tm .ace_constant.ace_library {color: rgb(6, 150, 14);}.ace-tm .ace_invalid {background-color: rgba(255, 0, 0, 0.1);color: red;}.ace-tm .ace_support.ace_function {color: rgb(60, 76, 114);}.ace-tm .ace_support.ace_constant {color: rgb(6, 150, 14);}.ace-tm .ace_support.ace_type,.ace-tm .ace_support.ace_class {color: rgb(109, 121, 222);}.ace-tm .ace_keyword.ace_operator {color: rgb(104, 118, 135);}.ace-tm .ace_string {color: rgb(3, 106, 7);}.ace-tm .ace_comment {color: rgb(76, 136, 107);}.ace-tm .ace_comment.ace_doc {color: rgb(0, 102, 255);}.ace-tm .ace_comment.ace_doc.ace_tag {color: rgb(128, 159, 191);}.ace-tm .ace_constant.ace_numeric {color: rgb(0, 0, 205);}.ace-tm .ace_variable {color: rgb(49, 132, 149);}.ace-tm .ace_xml-pe {color: rgb(104, 104, 91);}.ace-tm .ace_entity.ace_name.ace_function {color: #0000A2;}.ace-tm .ace_heading {color: rgb(12, 7, 255);}.ace-tm .ace_list {color:rgb(185, 6, 144);}.ace-tm .ace_meta.ace_tag {color:rgb(0, 22, 142);}.ace-tm .ace_string.ace_regex {color: rgb(255, 0, 0)}.ace-tm .ace_marker-layer .ace_selection {background: rgb(181, 213, 255);}.ace-tm.ace_multiselect .ace_selection.ace_start {box-shadow: 0 0 3px 0px white;}.ace-tm .ace_marker-layer .ace_step {background: rgb(252, 255, 0);}.ace-tm .ace_marker-layer .ace_stack {background: rgb(164, 229, 101);}.ace-tm .ace_marker-layer .ace_bracket {margin: -1px 0 0 -1px;border: 1px solid rgb(192, 192, 192);}.ace-tm .ace_marker-layer .ace_active-line {background: rgba(0, 0, 0, 0.07);}.ace-tm .ace_gutter-active-line {background-color : #dcdcdc;}.ace-tm .ace_marker-layer .ace_selected-word {background: rgb(250, 250, 255);border: 1px solid rgb(200, 200, 250);}.ace-tm .ace_indent-guide {background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAACCAYAAACZgbYnAAAAE0lEQVQImWP4////f4bLly//BwAmVgd1/w11/gAAAABJRU5ErkJggg==") right repeat-y;}'; + var r = e("../lib/dom"); + r.importCssString(t.cssText, t.cssClass) +}), define("ace/line_widgets", ["require", "exports", "module", "ace/lib/oop", "ace/lib/dom", "ace/range"], function(e, t, n) { + "use strict"; + + function o(e) { + this.session = e, this.session.widgetManager = this, this.session.getRowLength = this.getRowLength, this.session.$getWidgetScreenLength = this.$getWidgetScreenLength, this.updateOnChange = this.updateOnChange.bind(this), this.renderWidgets = this.renderWidgets.bind(this), this.measureWidgets = this.measureWidgets.bind(this), this.session._changedWidgets = [], this.$onChangeEditor = this.$onChangeEditor.bind(this), this.session.on("change", this.updateOnChange), this.session.on("changeFold", this.updateOnFold), this.session.on("changeEditor", this.$onChangeEditor) + } + var r = e("./lib/oop"), + i = e("./lib/dom"), + s = e("./range").Range; + (function() { + this.getRowLength = function(e) { + var t; + return this.lineWidgets ? t = this.lineWidgets[e] && this.lineWidgets[e].rowCount || 0 : t = 0, !this.$useWrapMode || !this.$wrapData[e] ? 1 + t : this.$wrapData[e].length + 1 + t + }, this.$getWidgetScreenLength = function() { + var e = 0; + return this.lineWidgets.forEach(function(t) { + t && t.rowCount && !t.hidden && (e += t.rowCount) + }), e + }, this.$onChangeEditor = function(e) { + this.attach(e.editor) + }, this.attach = function(e) { + e && e.widgetManager && e.widgetManager != this && e.widgetManager.detach(); + if (this.editor == e) return; + this.detach(), this.editor = e, e && (e.widgetManager = this, e.renderer.on("beforeRender", this.measureWidgets), e.renderer.on("afterRender", this.renderWidgets)) + }, this.detach = function(e) { + var t = this.editor; + if (!t) return; + this.editor = null, t.widgetManager = null, t.renderer.off("beforeRender", this.measureWidgets), t.renderer.off("afterRender", this.renderWidgets); + var n = this.session.lineWidgets; + n && n.forEach(function(e) { + e && e.el && e.el.parentNode && (e._inDocument = !1, e.el.parentNode.removeChild(e.el)) + }) + }, this.updateOnFold = function(e, t) { + var n = t.lineWidgets; + if (!n || !e.action) return; + var r = e.data, + i = r.start.row, + s = r.end.row, + o = e.action == "add"; + for (var u = i + 1; u < s; u++) n[u] && (n[u].hidden = o); + n[s] && (o ? n[i] ? n[s].hidden = o : n[i] = n[s] : (n[i] == n[s] && (n[i] = undefined), n[s].hidden = o)) + }, this.updateOnChange = function(e) { + var t = this.session.lineWidgets; + if (!t) return; + var n = e.start.row, + r = e.end.row - n; + if (r !== 0) + if (e.action == "remove") { + var i = t.splice(n + 1, r); + i.forEach(function(e) { + e && this.removeLineWidget(e) + }, this), this.$updateRows() + } else { + var s = new Array(r); + s.unshift(n, 0), t.splice.apply(t, s), this.$updateRows() + } + }, this.$updateRows = function() { + var e = this.session.lineWidgets; + if (!e) return; + var t = !0; + e.forEach(function(e, n) { + if (e) { + t = !1, e.row = n; + while (e.$oldWidget) e.$oldWidget.row = n, e = e.$oldWidget + } + }), t && (this.session.lineWidgets = null) + }, this.addLineWidget = function(e) { + this.session.lineWidgets || (this.session.lineWidgets = new Array(this.session.getLength())); + var t = this.session.lineWidgets[e.row]; + t && (e.$oldWidget = t, t.el && t.el.parentNode && (t.el.parentNode.removeChild(t.el), t._inDocument = !1)), this.session.lineWidgets[e.row] = e, e.session = this.session; + var n = this.editor.renderer; + e.html && !e.el && (e.el = i.createElement("div"), e.el.innerHTML = e.html), e.el && (i.addCssClass(e.el, "ace_lineWidgetContainer"), e.el.style.position = "absolute", e.el.style.zIndex = 5, n.container.appendChild(e.el), e._inDocument = !0), e.coverGutter || (e.el.style.zIndex = 3), e.pixelHeight == null && (e.pixelHeight = e.el.offsetHeight), e.rowCount == null && (e.rowCount = e.pixelHeight / n.layerConfig.lineHeight); + var r = this.session.getFoldAt(e.row, 0); + e.$fold = r; + if (r) { + var s = this.session.lineWidgets; + e.row == r.end.row && !s[r.start.row] ? s[r.start.row] = e : e.hidden = !0 + } + return this.session._emit("changeFold", { + data: { + start: { + row: e.row + } + } + }), this.$updateRows(), this.renderWidgets(null, n), this.onWidgetChanged(e), e + }, this.removeLineWidget = function(e) { + e._inDocument = !1, e.session = null, e.el && e.el.parentNode && e.el.parentNode.removeChild(e.el); + if (e.editor && e.editor.destroy) try { + e.editor.destroy() + } catch (t) {} + if (this.session.lineWidgets) { + var n = this.session.lineWidgets[e.row]; + if (n == e) this.session.lineWidgets[e.row] = e.$oldWidget, e.$oldWidget && this.onWidgetChanged(e.$oldWidget); + else + while (n) { + if (n.$oldWidget == e) { + n.$oldWidget = e.$oldWidget; + break + } + n = n.$oldWidget + } + } + this.session._emit("changeFold", { + data: { + start: { + row: e.row + } + } + }), this.$updateRows() + }, this.getWidgetsAtRow = function(e) { + var t = this.session.lineWidgets, + n = t && t[e], + r = []; + while (n) r.push(n), n = n.$oldWidget; + return r + }, this.onWidgetChanged = function(e) { + this.session._changedWidgets.push(e), this.editor && this.editor.renderer.updateFull() + }, this.measureWidgets = function(e, t) { + var n = this.session._changedWidgets, + r = t.layerConfig; + if (!n || !n.length) return; + var i = Infinity; + for (var s = 0; s < n.length; s++) { + var o = n[s]; + if (!o || !o.el) continue; + if (o.session != this.session) continue; + if (!o._inDocument) { + if (this.session.lineWidgets[o.row] != o) continue; + o._inDocument = !0, t.container.appendChild(o.el) + } + o.h = o.el.offsetHeight, o.fixedWidth || (o.w = o.el.offsetWidth, o.screenWidth = Math.ceil(o.w / r.characterWidth)); + var u = o.h / r.lineHeight; + o.coverLine && (u -= this.session.getRowLineCount(o.row), u < 0 && (u = 0)), o.rowCount != u && (o.rowCount = u, o.row < i && (i = o.row)) + } + i != Infinity && (this.session._emit("changeFold", { + data: { + start: { + row: i + } + } + }), this.session.lineWidgetWidth = null), this.session._changedWidgets = [] + }, this.renderWidgets = function(e, t) { + var n = t.layerConfig, + r = this.session.lineWidgets; + if (!r) return; + var i = Math.min(this.firstRow, n.firstRow), + s = Math.max(this.lastRow, n.lastRow, r.length); + while (i > 0 && !r[i]) i--; + this.firstRow = n.firstRow, this.lastRow = n.lastRow, t.$cursorLayer.config = n; + for (var o = i; o <= s; o++) { + var u = r[o]; + if (!u || !u.el) continue; + if (u.hidden) { + u.el.style.top = -100 - (u.pixelHeight || 0) + "px"; + continue + } + u._inDocument || (u._inDocument = !0, t.container.appendChild(u.el)); + var a = t.$cursorLayer.getPixelPosition({ + row: o, + column: 0 + }, !0).top; + u.coverLine || (a += n.lineHeight * this.session.getRowLineCount(u.row)), u.el.style.top = a - n.offset + "px"; + var f = u.coverGutter ? 0 : t.gutterWidth; + u.fixedWidth || (f -= t.scrollLeft), u.el.style.left = f + "px", u.fullWidth && u.screenWidth && (u.el.style.minWidth = n.width + 2 * n.padding + "px"), u.fixedWidth ? u.el.style.right = t.scrollBar.getWidth() + "px" : u.el.style.right = "" + } + } + }).call(o.prototype), t.LineWidgets = o +}), define("ace/ext/error_marker", ["require", "exports", "module", "ace/line_widgets", "ace/lib/dom", "ace/range"], function(e, t, n) { + "use strict"; + + function o(e, t, n) { + var r = 0, + i = e.length - 1; + while (r <= i) { + var s = r + i >> 1, + o = n(t, e[s]); + if (o > 0) r = s + 1; + else { + if (!(o < 0)) return s; + i = s - 1 + } + } + return -(r + 1) + } + + function u(e, t, n) { + var r = e.getAnnotations().sort(s.comparePoints); + if (!r.length) return; + var i = o(r, { + row: t, + column: -1 + }, s.comparePoints); + i < 0 && (i = -i - 1), i >= r.length ? i = n > 0 ? 0 : r.length - 1 : i === 0 && n < 0 && (i = r.length - 1); + var u = r[i]; + if (!u || !n) return; + if (u.row === t) { + do u = r[i += n]; while (u && u.row === t); + if (!u) return r.slice() + } + var a = []; + t = u.row; + do a[n < 0 ? "unshift" : "push"](u), u = r[i += n]; while (u && u.row == t); + return a.length && a + } + var r = e("../line_widgets").LineWidgets, + i = e("../lib/dom"), + s = e("../range").Range; + t.showErrorMarker = function(e, t) { + var n = e.session; + n.widgetManager || (n.widgetManager = new r(n), n.widgetManager.attach(e)); + var s = e.getCursorPosition(), + o = s.row, + a = n.widgetManager.getWidgetsAtRow(o).filter(function(e) { + return e.type == "errorMarker" + })[0]; + a ? a.destroy() : o -= t; + var f = u(n, o, t), + l; + if (f) { + var c = f[0]; + s.column = (c.pos && typeof c.column != "number" ? c.pos.sc : c.column) || 0, s.row = c.row, l = e.renderer.$gutterLayer.$annotations[s.row] + } else { + if (a) return; + l = { + text: ["Looks good!"], + className: "ace_ok" + } + } + e.session.unfold(s.row), e.selection.moveToPosition(s); + var h = { + row: s.row, + fixedWidth: !0, + coverGutter: !0, + el: i.createElement("div"), + type: "errorMarker" + }, + p = h.el.appendChild(i.createElement("div")), + d = h.el.appendChild(i.createElement("div")); + d.className = "error_widget_arrow " + l.className; + var v = e.renderer.$cursorLayer.getPixelPosition(s).left; + d.style.left = v + e.renderer.gutterWidth - 5 + "px", h.el.className = "error_widget_wrapper", p.className = "error_widget " + l.className, p.innerHTML = l.text.join("
"), p.appendChild(i.createElement("div")); + var m = function(e, t, n) { + if (t === 0 && (n === "esc" || n === "return")) return h.destroy(), { + command: "null" + } + }; + h.destroy = function() { + if (e.$mouseHandler.isMousePressed) return; + e.keyBinding.removeKeyboardHandler(m), n.widgetManager.removeLineWidget(h), e.off("changeSelection", h.destroy), e.off("changeSession", h.destroy), e.off("mouseup", h.destroy), e.off("change", h.destroy) + }, e.keyBinding.addKeyboardHandler(m), e.on("changeSelection", h.destroy), e.on("changeSession", h.destroy), e.on("mouseup", h.destroy), e.on("change", h.destroy), e.session.widgetManager.addLineWidget(h), h.el.onmousedown = e.focus.bind(e), e.renderer.scrollCursorIntoView(null, .5, { + bottom: h.el.offsetHeight + }) + }, i.importCssString(" .error_widget_wrapper { background: inherit; color: inherit; border:none } .error_widget { border-top: solid 2px; border-bottom: solid 2px; margin: 5px 0; padding: 10px 40px; white-space: pre-wrap; } .error_widget.ace_error, .error_widget_arrow.ace_error{ border-color: #ff5a5a } .error_widget.ace_warning, .error_widget_arrow.ace_warning{ border-color: #F1D817 } .error_widget.ace_info, .error_widget_arrow.ace_info{ border-color: #5a5a5a } .error_widget.ace_ok, .error_widget_arrow.ace_ok{ border-color: #5aaa5a } .error_widget_arrow { position: absolute; border: solid 5px; border-top-color: transparent!important; border-right-color: transparent!important; border-left-color: transparent!important; top: -5px; }", "") +}), define("ace/ace", ["require", "exports", "module", "ace/lib/fixoldbrowsers", "ace/lib/dom", "ace/lib/event", "ace/editor", "ace/edit_session", "ace/undomanager", "ace/virtual_renderer", "ace/worker/worker_client", "ace/keyboard/hash_handler", "ace/placeholder", "ace/multi_select", "ace/mode/folding/fold_mode", "ace/theme/textmate", "ace/ext/error_marker", "ace/config"], function(e, t, n) { + "use strict"; + e("./lib/fixoldbrowsers"); + var r = e("./lib/dom"), + i = e("./lib/event"), + s = e("./editor").Editor, + o = e("./edit_session").EditSession, + u = e("./undomanager").UndoManager, + a = e("./virtual_renderer").VirtualRenderer; + e("./worker/worker_client"), e("./keyboard/hash_handler"), e("./placeholder"), e("./multi_select"), e("./mode/folding/fold_mode"), e("./theme/textmate"), e("./ext/error_marker"), t.config = e("./config"), t.requireAce = e, typeof define == "function" && (t.define = define), t.edit = function(e) { + if (typeof e == "string") { + var n = e; + e = document.getElementById(n); + if (!e) throw new Error("ace.edit can't find div #" + n) + } + if (e && e.env && e.env.editor instanceof s) return e.env.editor; + var o = ""; + if (e && /input|textarea/i.test(e.tagName)) { + var u = e; + o = u.value, e = r.createElement("pre"), u.parentNode.replaceChild(e, u) + } else e && (o = r.getInnerText(e), e.innerHTML = ""); + var f = t.createEditSession(o), + l = new s(new a(e)); + l.setSession(f); + var c = { + document: f, + editor: l, + onResize: l.resize.bind(l, null) + }; + return u && (c.textarea = u), i.addListener(window, "resize", c.onResize), l.on("destroy", function() { + i.removeListener(window, "resize", c.onResize), c.editor.container.env = null + }), l.container.env = l.env = c, l + }, t.createEditSession = function(e, t) { + var n = new o(e, t); + return n.setUndoManager(new u), n + }, t.EditSession = o, t.UndoManager = u, t.version = "1.2.9" +}), define("ace/theme/monokai", ["require", "exports", "module", "ace/lib/dom"], function(e, t, n) { + t.isDark = !0, t.cssClass = "ace-monokai", t.cssText = ".ace-monokai .ace_gutter {background: #2F3129;color: #8F908A}.ace-monokai .ace_print-margin {width: 1px;background: #555651}.ace-monokai {background-color: #272822;color: #F8F8F2}.ace-monokai .ace_cursor {color: #F8F8F0}.ace-monokai .ace_marker-layer .ace_selection {background: #49483E}.ace-monokai.ace_multiselect .ace_selection.ace_start {box-shadow: 0 0 3px 0px #272822;}.ace-monokai .ace_marker-layer .ace_step {background: rgb(102, 82, 0)}.ace-monokai .ace_marker-layer .ace_bracket {margin: -1px 0 0 -1px;border: 1px solid #49483E}.ace-monokai .ace_marker-layer .ace_active-line {background: #202020}.ace-monokai .ace_gutter-active-line {background-color: #272727}.ace-monokai .ace_marker-layer .ace_selected-word {border: 1px solid #49483E}.ace-monokai .ace_invisible {color: #52524d}.ace-monokai .ace_entity.ace_name.ace_tag,.ace-monokai .ace_keyword,.ace-monokai .ace_meta.ace_tag,.ace-monokai .ace_storage {color: #F92672}.ace-monokai .ace_punctuation,.ace-monokai .ace_punctuation.ace_tag {color: #fff}.ace-monokai .ace_constant.ace_character,.ace-monokai .ace_constant.ace_language,.ace-monokai .ace_constant.ace_numeric,.ace-monokai .ace_constant.ace_other {color: #AE81FF}.ace-monokai .ace_invalid {color: #F8F8F0;background-color: #F92672}.ace-monokai .ace_invalid.ace_deprecated {color: #F8F8F0;background-color: #AE81FF}.ace-monokai .ace_support.ace_constant,.ace-monokai .ace_support.ace_function {color: #66D9EF}.ace-monokai .ace_fold {background-color: #A6E22E;border-color: #F8F8F2}.ace-monokai .ace_storage.ace_type,.ace-monokai .ace_support.ace_class,.ace-monokai .ace_support.ace_type {font-style: italic;color: #66D9EF}.ace-monokai .ace_entity.ace_name.ace_function,.ace-monokai .ace_entity.ace_other,.ace-monokai .ace_entity.ace_other.ace_attribute-name,.ace-monokai .ace_variable {color: #A6E22E}.ace-monokai .ace_variable.ace_parameter {font-style: italic;color: #FD971F}.ace-monokai .ace_string {color: #E6DB74}.ace-monokai .ace_comment {color: #75715E}.ace-monokai .ace_indent-guide {background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAACCAYAAACZgbYnAAAAEklEQVQImWPQ0FD0ZXBzd/wPAAjVAoxeSgNeAAAAAElFTkSuQmCC) right repeat-y}"; + var r = e("../lib/dom"); + r.importCssString(t.cssText, t.cssClass) +}), define("ace/mode/css_highlight_rules", ["require", "exports", "module", "ace/lib/oop", "ace/lib/lang", "ace/mode/text_highlight_rules"], function(e, t, n) { + "use strict"; + var r = e("../lib/oop"), + i = e("../lib/lang"), + s = e("./text_highlight_rules").TextHighlightRules, + o = t.supportType = "align-content|align-items|align-self|all|animation|animation-delay|animation-direction|animation-duration|animation-fill-mode|animation-iteration-count|animation-name|animation-play-state|animation-timing-function|backface-visibility|background|background-attachment|background-blend-mode|background-clip|background-color|background-image|background-origin|background-position|background-repeat|background-size|border|border-bottom|border-bottom-color|border-bottom-left-radius|border-bottom-right-radius|border-bottom-style|border-bottom-width|border-collapse|border-color|border-image|border-image-outset|border-image-repeat|border-image-slice|border-image-source|border-image-width|border-left|border-left-color|border-left-style|border-left-width|border-radius|border-right|border-right-color|border-right-style|border-right-width|border-spacing|border-style|border-top|border-top-color|border-top-left-radius|border-top-right-radius|border-top-style|border-top-width|border-width|bottom|box-shadow|box-sizing|caption-side|clear|clip|color|column-count|column-fill|column-gap|column-rule|column-rule-color|column-rule-style|column-rule-width|column-span|column-width|columns|content|counter-increment|counter-reset|cursor|direction|display|empty-cells|filter|flex|flex-basis|flex-direction|flex-flow|flex-grow|flex-shrink|flex-wrap|float|font|font-family|font-size|font-size-adjust|font-stretch|font-style|font-variant|font-weight|hanging-punctuation|height|justify-content|left|letter-spacing|line-height|list-style|list-style-image|list-style-position|list-style-type|margin|margin-bottom|margin-left|margin-right|margin-top|max-height|max-width|min-height|min-width|nav-down|nav-index|nav-left|nav-right|nav-up|opacity|order|outline|outline-color|outline-offset|outline-style|outline-width|overflow|overflow-x|overflow-y|padding|padding-bottom|padding-left|padding-right|padding-top|page-break-after|page-break-before|page-break-inside|perspective|perspective-origin|position|quotes|resize|right|tab-size|table-layout|text-align|text-align-last|text-decoration|text-decoration-color|text-decoration-line|text-decoration-style|text-indent|text-justify|text-overflow|text-shadow|text-transform|top|transform|transform-origin|transform-style|transition|transition-delay|transition-duration|transition-property|transition-timing-function|unicode-bidi|vertical-align|visibility|white-space|width|word-break|word-spacing|word-wrap|z-index", + u = t.supportFunction = "rgb|rgba|url|attr|counter|counters", + a = t.supportConstant = "absolute|after-edge|after|all-scroll|all|alphabetic|always|antialiased|armenian|auto|avoid-column|avoid-page|avoid|balance|baseline|before-edge|before|below|bidi-override|block-line-height|block|bold|bolder|border-box|both|bottom|box|break-all|break-word|capitalize|caps-height|caption|center|central|char|circle|cjk-ideographic|clone|close-quote|col-resize|collapse|column|consider-shifts|contain|content-box|cover|crosshair|cubic-bezier|dashed|decimal-leading-zero|decimal|default|disabled|disc|disregard-shifts|distribute-all-lines|distribute-letter|distribute-space|distribute|dotted|double|e-resize|ease-in|ease-in-out|ease-out|ease|ellipsis|end|exclude-ruby|fill|fixed|georgian|glyphs|grid-height|groove|hand|hanging|hebrew|help|hidden|hiragana-iroha|hiragana|horizontal|icon|ideograph-alpha|ideograph-numeric|ideograph-parenthesis|ideograph-space|ideographic|inactive|include-ruby|inherit|initial|inline-block|inline-box|inline-line-height|inline-table|inline|inset|inside|inter-ideograph|inter-word|invert|italic|justify|katakana-iroha|katakana|keep-all|last|left|lighter|line-edge|line-through|line|linear|list-item|local|loose|lower-alpha|lower-greek|lower-latin|lower-roman|lowercase|lr-tb|ltr|mathematical|max-height|max-size|medium|menu|message-box|middle|move|n-resize|ne-resize|newspaper|no-change|no-close-quote|no-drop|no-open-quote|no-repeat|none|normal|not-allowed|nowrap|nw-resize|oblique|open-quote|outset|outside|overline|padding-box|page|pointer|pre-line|pre-wrap|pre|preserve-3d|progress|relative|repeat-x|repeat-y|repeat|replaced|reset-size|ridge|right|round|row-resize|rtl|s-resize|scroll|se-resize|separate|slice|small-caps|small-caption|solid|space|square|start|static|status-bar|step-end|step-start|steps|stretch|strict|sub|super|sw-resize|table-caption|table-cell|table-column-group|table-column|table-footer-group|table-header-group|table-row-group|table-row|table|tb-rl|text-after-edge|text-before-edge|text-bottom|text-size|text-top|text|thick|thin|transparent|underline|upper-alpha|upper-latin|upper-roman|uppercase|use-script|vertical-ideographic|vertical-text|visible|w-resize|wait|whitespace|z-index|zero", + f = t.supportConstantColor = "aliceblue|antiquewhite|aqua|aquamarine|azure|beige|bisque|black|blanchedalmond|blue|blueviolet|brown|burlywood|cadetblue|chartreuse|chocolate|coral|cornflowerblue|cornsilk|crimson|cyan|darkblue|darkcyan|darkgoldenrod|darkgray|darkgreen|darkgrey|darkkhaki|darkmagenta|darkolivegreen|darkorange|darkorchid|darkred|darksalmon|darkseagreen|darkslateblue|darkslategray|darkslategrey|darkturquoise|darkviolet|deeppink|deepskyblue|dimgray|dimgrey|dodgerblue|firebrick|floralwhite|forestgreen|fuchsia|gainsboro|ghostwhite|gold|goldenrod|gray|green|greenyellow|grey|honeydew|hotpink|indianred|indigo|ivory|khaki|lavender|lavenderblush|lawngreen|lemonchiffon|lightblue|lightcoral|lightcyan|lightgoldenrodyellow|lightgray|lightgreen|lightgrey|lightpink|lightsalmon|lightseagreen|lightskyblue|lightslategray|lightslategrey|lightsteelblue|lightyellow|lime|limegreen|linen|magenta|maroon|mediumaquamarine|mediumblue|mediumorchid|mediumpurple|mediumseagreen|mediumslateblue|mediumspringgreen|mediumturquoise|mediumvioletred|midnightblue|mintcream|mistyrose|moccasin|navajowhite|navy|oldlace|olive|olivedrab|orange|orangered|orchid|palegoldenrod|palegreen|paleturquoise|palevioletred|papayawhip|peachpuff|peru|pink|plum|powderblue|purple|rebeccapurple|red|rosybrown|royalblue|saddlebrown|salmon|sandybrown|seagreen|seashell|sienna|silver|skyblue|slateblue|slategray|slategrey|snow|springgreen|steelblue|tan|teal|thistle|tomato|turquoise|violet|wheat|white|whitesmoke|yellow|yellowgreen", + l = t.supportConstantFonts = "arial|century|comic|courier|cursive|fantasy|garamond|georgia|helvetica|impact|lucida|symbol|system|tahoma|times|trebuchet|utopia|verdana|webdings|sans-serif|serif|monospace", + c = t.numRe = "\\-?(?:(?:[0-9]+(?:\\.[0-9]+)?)|(?:\\.[0-9]+))", + h = t.pseudoElements = "(\\:+)\\b(after|before|first-letter|first-line|moz-selection|selection)\\b", + p = t.pseudoClasses = "(:)\\b(active|checked|disabled|empty|enabled|first-child|first-of-type|focus|hover|indeterminate|invalid|last-child|last-of-type|link|not|nth-child|nth-last-child|nth-last-of-type|nth-of-type|only-child|only-of-type|required|root|target|valid|visited)\\b", + d = function() { + var e = this.createKeywordMapper({ + "support.function": u, + "support.constant": a, + "support.type": o, + "support.constant.color": f, + "support.constant.fonts": l + }, "text", !0); + this.$rules = { + start: [{ + include: ["strings", "url", "comments"] + }, { + token: "paren.lparen", + regex: "\\{", + next: "ruleset" + }, { + token: "paren.rparen", + regex: "\\}" + }, { + token: "string", + regex: "@", + next: "media" + }, { + token: "keyword", + regex: "#[a-z0-9-_]+" + }, { + token: "keyword", + regex: "%" + }, { + token: "variable", + regex: "\\.[a-z0-9-_]+" + }, { + token: "string", + regex: ":[a-z0-9-_]+" + }, { + token: "constant.numeric", + regex: c + }, { + token: "constant", + regex: "[a-z0-9-_]+" + }, { + caseInsensitive: !0 + }], + media: [{ + include: ["strings", "url", "comments"] + }, { + token: "paren.lparen", + regex: "\\{", + next: "start" + }, { + token: "paren.rparen", + regex: "\\}", + next: "start" + }, { + token: "string", + regex: ";", + next: "start" + }, { + token: "keyword", + regex: "(?:media|supports|document|charset|import|namespace|media|supports|document|page|font|keyframes|viewport|counter-style|font-feature-values|swash|ornaments|annotation|stylistic|styleset|character-variant)" + }], + comments: [{ + token: "comment", + regex: "\\/\\*", + push: [{ + token: "comment", + regex: "\\*\\/", + next: "pop" + }, { + defaultToken: "comment" + }] + }], + ruleset: [{ + regex: "-(webkit|ms|moz|o)-", + token: "text" + }, { + token: "paren.rparen", + regex: "\\}", + next: "start" + }, { + include: ["strings", "url", "comments"] + }, { + token: ["constant.numeric", "keyword"], + regex: "(" + c + ")(ch|cm|deg|em|ex|fr|gd|grad|Hz|in|kHz|mm|ms|pc|pt|px|rad|rem|s|turn|vh|vm|vw|%)" + }, { + token: "constant.numeric", + regex: c + }, { + token: "constant.numeric", + regex: "#[a-f0-9]{6}" + }, { + token: "constant.numeric", + regex: "#[a-f0-9]{3}" + }, { + token: ["punctuation", "entity.other.attribute-name.pseudo-element.css"], + regex: h + }, { + token: ["punctuation", "entity.other.attribute-name.pseudo-class.css"], + regex: p + }, { + include: "url" + }, { + token: e, + regex: "\\-?[a-zA-Z_][a-zA-Z0-9_\\-]*" + }, { + caseInsensitive: !0 + }], + url: [{ + token: "support.function", + regex: "(?:url(:?-prefix)?|domain|regexp)\\(", + push: [{ + token: "support.function", + regex: "\\)", + next: "pop" + }, { + defaultToken: "string" + }] + }], + strings: [{ + token: "string.start", + regex: "'", + push: [{ + token: "string.end", + regex: "'|$", + next: "pop" + }, { + include: "escapes" + }, { + token: "constant.language.escape", + regex: /\\$/, + consumeLineEnd: !0 + }, { + defaultToken: "string" + }] + }, { + token: "string.start", + regex: '"', + push: [{ + token: "string.end", + regex: '"|$', + next: "pop" + }, { + include: "escapes" + }, { + token: "constant.language.escape", + regex: /\\$/, + consumeLineEnd: !0 + }, { + defaultToken: "string" + }] + }], + escapes: [{ + token: "constant.language.escape", + regex: /\\([a-fA-F\d]{1,6}|[^a-fA-F\d])/ + }] + }, this.normalizeRules() + }; + r.inherits(d, s), t.CssHighlightRules = d +}), define("ace/mode/matching_brace_outdent", ["require", "exports", "module", "ace/range"], function(e, t, n) { + "use strict"; + var r = e("../range").Range, + i = function() {}; + (function() { + this.checkOutdent = function(e, t) { + return /^\s+$/.test(e) ? /^\s*\}/.test(t) : !1 + }, this.autoOutdent = function(e, t) { + var n = e.getLine(t), + i = n.match(/^(\s*\})/); + if (!i) return 0; + var s = i[1].length, + o = e.findMatchingBracket({ + row: t, + column: s + }); + if (!o || o.row == t) return 0; + var u = this.$getIndent(e.getLine(o.row)); + e.replace(new r(t, 0, t, s - 1), u) + }, this.$getIndent = function(e) { + return e.match(/^\s*/)[0] + } + }).call(i.prototype), t.MatchingBraceOutdent = i +}), define("ace/mode/css_completions", ["require", "exports", "module"], function(e, t, n) { + "use strict"; + var r = { + background: { + "#$0": 1 + }, + "background-color": { + "#$0": 1, + transparent: 1, + fixed: 1 + }, + "background-image": { + "url('/$0')": 1 + }, + "background-repeat": { + repeat: 1, + "repeat-x": 1, + "repeat-y": 1, + "no-repeat": 1, + inherit: 1 + }, + "background-position": { + bottom: 2, + center: 2, + left: 2, + right: 2, + top: 2, + inherit: 2 + }, + "background-attachment": { + scroll: 1, + fixed: 1 + }, + "background-size": { + cover: 1, + contain: 1 + }, + "background-clip": { + "border-box": 1, + "padding-box": 1, + "content-box": 1 + }, + "background-origin": { + "border-box": 1, + "padding-box": 1, + "content-box": 1 + }, + border: { + "solid $0": 1, + "dashed $0": 1, + "dotted $0": 1, + "#$0": 1 + }, + "border-color": { + "#$0": 1 + }, + "border-style": { + solid: 2, + dashed: 2, + dotted: 2, + "double": 2, + groove: 2, + hidden: 2, + inherit: 2, + inset: 2, + none: 2, + outset: 2, + ridged: 2 + }, + "border-collapse": { + collapse: 1, + separate: 1 + }, + bottom: { + px: 1, + em: 1, + "%": 1 + }, + clear: { + left: 1, + right: 1, + both: 1, + none: 1 + }, + color: { + "#$0": 1, + "rgb(#$00,0,0)": 1 + }, + cursor: { + "default": 1, + pointer: 1, + move: 1, + text: 1, + wait: 1, + help: 1, + progress: 1, + "n-resize": 1, + "ne-resize": 1, + "e-resize": 1, + "se-resize": 1, + "s-resize": 1, + "sw-resize": 1, + "w-resize": 1, + "nw-resize": 1 + }, + display: { + none: 1, + block: 1, + inline: 1, + "inline-block": 1, + "table-cell": 1 + }, + "empty-cells": { + show: 1, + hide: 1 + }, + "float": { + left: 1, + right: 1, + none: 1 + }, + "font-family": { + Arial: 2, + "Comic Sans MS": 2, + Consolas: 2, + "Courier New": 2, + Courier: 2, + Georgia: 2, + Monospace: 2, + "Sans-Serif": 2, + "Segoe UI": 2, + Tahoma: 2, + "Times New Roman": 2, + "Trebuchet MS": 2, + Verdana: 1 + }, + "font-size": { + px: 1, + em: 1, + "%": 1 + }, + "font-weight": { + bold: 1, + normal: 1 + }, + "font-style": { + italic: 1, + normal: 1 + }, + "font-variant": { + normal: 1, + "small-caps": 1 + }, + height: { + px: 1, + em: 1, + "%": 1 + }, + left: { + px: 1, + em: 1, + "%": 1 + }, + "letter-spacing": { + normal: 1 + }, + "line-height": { + normal: 1 + }, + "list-style-type": { + none: 1, + disc: 1, + circle: 1, + square: 1, + decimal: 1, + "decimal-leading-zero": 1, + "lower-roman": 1, + "upper-roman": 1, + "lower-greek": 1, + "lower-latin": 1, + "upper-latin": 1, + georgian: 1, + "lower-alpha": 1, + "upper-alpha": 1 + }, + margin: { + px: 1, + em: 1, + "%": 1 + }, + "margin-right": { + px: 1, + em: 1, + "%": 1 + }, + "margin-left": { + px: 1, + em: 1, + "%": 1 + }, + "margin-top": { + px: 1, + em: 1, + "%": 1 + }, + "margin-bottom": { + px: 1, + em: 1, + "%": 1 + }, + "max-height": { + px: 1, + em: 1, + "%": 1 + }, + "max-width": { + px: 1, + em: 1, + "%": 1 + }, + "min-height": { + px: 1, + em: 1, + "%": 1 + }, + "min-width": { + px: 1, + em: 1, + "%": 1 + }, + overflow: { + hidden: 1, + visible: 1, + auto: 1, + scroll: 1 + }, + "overflow-x": { + hidden: 1, + visible: 1, + auto: 1, + scroll: 1 + }, + "overflow-y": { + hidden: 1, + visible: 1, + auto: 1, + scroll: 1 + }, + padding: { + px: 1, + em: 1, + "%": 1 + }, + "padding-top": { + px: 1, + em: 1, + "%": 1 + }, + "padding-right": { + px: 1, + em: 1, + "%": 1 + }, + "padding-bottom": { + px: 1, + em: 1, + "%": 1 + }, + "padding-left": { + px: 1, + em: 1, + "%": 1 + }, + "page-break-after": { + auto: 1, + always: 1, + avoid: 1, + left: 1, + right: 1 + }, + "page-break-before": { + auto: 1, + always: 1, + avoid: 1, + left: 1, + right: 1 + }, + position: { + absolute: 1, + relative: 1, + fixed: 1, + "static": 1 + }, + right: { + px: 1, + em: 1, + "%": 1 + }, + "table-layout": { + fixed: 1, + auto: 1 + }, + "text-decoration": { + none: 1, + underline: 1, + "line-through": 1, + blink: 1 + }, + "text-align": { + left: 1, + right: 1, + center: 1, + justify: 1 + }, + "text-transform": { + capitalize: 1, + uppercase: 1, + lowercase: 1, + none: 1 + }, + top: { + px: 1, + em: 1, + "%": 1 + }, + "vertical-align": { + top: 1, + bottom: 1 + }, + visibility: { + hidden: 1, + visible: 1 + }, + "white-space": { + nowrap: 1, + normal: 1, + pre: 1, + "pre-line": 1, + "pre-wrap": 1 + }, + width: { + px: 1, + em: 1, + "%": 1 + }, + "word-spacing": { + normal: 1 + }, + filter: { + "alpha(opacity=$0100)": 1 + }, + "text-shadow": { + "$02px 2px 2px #777": 1 + }, + "text-overflow": { + "ellipsis-word": 1, + clip: 1, + ellipsis: 1 + }, + "-moz-border-radius": 1, + "-moz-border-radius-topright": 1, + "-moz-border-radius-bottomright": 1, + "-moz-border-radius-topleft": 1, + "-moz-border-radius-bottomleft": 1, + "-webkit-border-radius": 1, + "-webkit-border-top-right-radius": 1, + "-webkit-border-top-left-radius": 1, + "-webkit-border-bottom-right-radius": 1, + "-webkit-border-bottom-left-radius": 1, + "-moz-box-shadow": 1, + "-webkit-box-shadow": 1, + transform: { + "rotate($00deg)": 1, + "skew($00deg)": 1 + }, + "-moz-transform": { + "rotate($00deg)": 1, + "skew($00deg)": 1 + }, + "-webkit-transform": { + "rotate($00deg)": 1, + "skew($00deg)": 1 + } + }, + i = function() {}; + (function() { + this.completionsDefined = !1, this.defineCompletions = function() { + if (document) { + var e = document.createElement("c").style; + for (var t in e) { + if (typeof e[t] != "string") continue; + var n = t.replace(/[A-Z]/g, function(e) { + return "-" + e.toLowerCase() + }); + r.hasOwnProperty(n) || (r[n] = 1) + } + } + this.completionsDefined = !0 + }, this.getCompletions = function(e, t, n, r) { + this.completionsDefined || this.defineCompletions(); + var i = t.getTokenAt(n.row, n.column); + if (!i) return []; + if (e === "ruleset") { + var s = t.getLine(n.row).substr(0, n.column); + return /:[^;]+$/.test(s) ? (/([\w\-]+):[^:]*$/.test(s), this.getPropertyValueCompletions(e, t, n, r)) : this.getPropertyCompletions(e, t, n, r) + } + return [] + }, this.getPropertyCompletions = function(e, t, n, i) { + var s = Object.keys(r); + return s.map(function(e) { + return { + caption: e, + snippet: e + ": $0;", + meta: "property", + score: Number.MAX_VALUE + } + }) + }, this.getPropertyValueCompletions = function(e, t, n, i) { + var s = t.getLine(n.row).substr(0, n.column), + o = (/([\w\-]+):[^:]*$/.exec(s) || {})[1]; + if (!o) return []; + var u = []; + return o in r && typeof r[o] == "object" && (u = Object.keys(r[o])), u.map(function(e) { + return { + caption: e, + snippet: e, + meta: "property value", + score: Number.MAX_VALUE + } + }) + } + }).call(i.prototype), t.CssCompletions = i +}), define("ace/mode/behaviour/css", ["require", "exports", "module", "ace/lib/oop", "ace/mode/behaviour", "ace/mode/behaviour/cstyle", "ace/token_iterator"], function(e, t, n) { + "use strict"; + var r = e("../../lib/oop"), + i = e("../behaviour").Behaviour, + s = e("./cstyle").CstyleBehaviour, + o = e("../../token_iterator").TokenIterator, + u = function() { + this.inherit(s), this.add("colon", "insertion", function(e, t, n, r, i) { + if (i === ":") { + var s = n.getCursorPosition(), + u = new o(r, s.row, s.column), + a = u.getCurrentToken(); + a && a.value.match(/\s+/) && (a = u.stepBackward()); + if (a && a.type === "support.type") { + var f = r.doc.getLine(s.row), + l = f.substring(s.column, s.column + 1); + if (l === ":") return { + text: "", + selection: [1, 1] + }; + if (!f.substring(s.column).match(/^\s*;/)) return { + text: ":;", + selection: [1, 1] + } + } + } + }), this.add("colon", "deletion", function(e, t, n, r, i) { + var s = r.doc.getTextRange(i); + if (!i.isMultiLine() && s === ":") { + var u = n.getCursorPosition(), + a = new o(r, u.row, u.column), + f = a.getCurrentToken(); + f && f.value.match(/\s+/) && (f = a.stepBackward()); + if (f && f.type === "support.type") { + var l = r.doc.getLine(i.start.row), + c = l.substring(i.end.column, i.end.column + 1); + if (c === ";") return i.end.column++, i + } + } + }), this.add("semicolon", "insertion", function(e, t, n, r, i) { + if (i === ";") { + var s = n.getCursorPosition(), + o = r.doc.getLine(s.row), + u = o.substring(s.column, s.column + 1); + if (u === ";") return { + text: "", + selection: [1, 1] + } + } + }) + }; + r.inherits(u, s), t.CssBehaviour = u +}), define("ace/mode/folding/cstyle", ["require", "exports", "module", "ace/lib/oop", "ace/range", "ace/mode/folding/fold_mode"], function(e, t, n) { + "use strict"; + var r = e("../../lib/oop"), + i = e("../../range").Range, + s = e("./fold_mode").FoldMode, + o = t.FoldMode = function(e) { + e && (this.foldingStartMarker = new RegExp(this.foldingStartMarker.source.replace(/\|[^|]*?$/, "|" + e.start)), this.foldingStopMarker = new RegExp(this.foldingStopMarker.source.replace(/\|[^|]*?$/, "|" + e.end))) + }; + r.inherits(o, s), + function() { + this.foldingStartMarker = /([\{\[\(])[^\}\]\)]*$|^\s*(\/\*)/, this.foldingStopMarker = /^[^\[\{\(]*([\}\]\)])|^[\s\*]*(\*\/)/, this.singleLineBlockCommentRe = /^\s*(\/\*).*\*\/\s*$/, this.tripleStarBlockCommentRe = /^\s*(\/\*\*\*).*\*\/\s*$/, this.startRegionRe = /^\s*(\/\*|\/\/)#?region\b/, this._getFoldWidgetBase = this.getFoldWidget, this.getFoldWidget = function(e, t, n) { + var r = e.getLine(n); + if (this.singleLineBlockCommentRe.test(r) && !this.startRegionRe.test(r) && !this.tripleStarBlockCommentRe.test(r)) return ""; + var i = this._getFoldWidgetBase(e, t, n); + return !i && this.startRegionRe.test(r) ? "start" : i + }, this.getFoldWidgetRange = function(e, t, n, r) { + var i = e.getLine(n); + if (this.startRegionRe.test(i)) return this.getCommentRegionBlock(e, i, n); + var s = i.match(this.foldingStartMarker); + if (s) { + var o = s.index; + if (s[1]) return this.openingBracketBlock(e, s[1], n, o); + var u = e.getCommentFoldRange(n, o + s[0].length, 1); + return u && !u.isMultiLine() && (r ? u = this.getSectionRange(e, n) : t != "all" && (u = null)), u + } + if (t === "markbegin") return; + var s = i.match(this.foldingStopMarker); + if (s) { + var o = s.index + s[0].length; + return s[1] ? this.closingBracketBlock(e, s[1], n, o) : e.getCommentFoldRange(n, o, -1) + } + }, this.getSectionRange = function(e, t) { + var n = e.getLine(t), + r = n.search(/\S/), + s = t, + o = n.length; + t += 1; + var u = t, + a = e.getLength(); + while (++t < a) { + n = e.getLine(t); + var f = n.search(/\S/); + if (f === -1) continue; + if (r > f) break; + var l = this.getFoldWidgetRange(e, "all", t); + if (l) { + if (l.start.row <= s) break; + if (l.isMultiLine()) t = l.end.row; + else if (r == f) break + } + u = t + } + return new i(s, o, u, e.getLine(u).length) + }, this.getCommentRegionBlock = function(e, t, n) { + var r = t.search(/\s*$/), + s = e.getLength(), + o = n, + u = /^\s*(?:\/\*|\/\/|--)#?(end)?region\b/, + a = 1; + while (++n < s) { + t = e.getLine(n); + var f = u.exec(t); + if (!f) continue; + f[1] ? a-- : a++; + if (!a) break + } + var l = n; + if (l > o) return new i(o, r, l, t.length) + } + }.call(o.prototype) +}), define("ace/mode/css", ["require", "exports", "module", "ace/lib/oop", "ace/mode/text", "ace/mode/css_highlight_rules", "ace/mode/matching_brace_outdent", "ace/worker/worker_client", "ace/mode/css_completions", "ace/mode/behaviour/css", "ace/mode/folding/cstyle"], function(e, t, n) { + "use strict"; + var r = e("../lib/oop"), + i = e("./text").Mode, + s = e("./css_highlight_rules").CssHighlightRules, + o = e("./matching_brace_outdent").MatchingBraceOutdent, + u = e("../worker/worker_client").WorkerClient, + a = e("./css_completions").CssCompletions, + f = e("./behaviour/css").CssBehaviour, + l = e("./folding/cstyle").FoldMode, + c = function() { + this.HighlightRules = s, this.$outdent = new o, this.$behaviour = new f, this.$completer = new a, this.foldingRules = new l + }; + r.inherits(c, i), + function() { + this.foldingRules = "cStyle", this.blockComment = { + start: "/*", + end: "*/" + }, this.getNextLineIndent = function(e, t, n) { + var r = this.$getIndent(t), + i = this.getTokenizer().getLineTokens(t, e).tokens; + if (i.length && i[i.length - 1].type == "comment") return r; + var s = t.match(/^.*\{\s*$/); + return s && (r += n), r + }, this.checkOutdent = function(e, t, n) { + return this.$outdent.checkOutdent(t, n) + }, this.autoOutdent = function(e, t, n) { + this.$outdent.autoOutdent(t, n) + }, this.getCompletions = function(e, t, n, r) { + return this.$completer.getCompletions(e, t, n, r) + }, this.createWorker = function(e) { + var t = new u(["ace"], "ace/mode/css_worker", "Worker"); + return t.attachToDocument(e.getDocument()), t.on("annotate", function(t) { + e.setAnnotations(t.data) + }), t.on("terminate", function() { + e.clearAnnotations() + }), t + }, this.$id = "ace/mode/css" + }.call(c.prototype), t.Mode = c +}); +(function() { + window.requireAce(["ace/ace"], function(a) { + if (a) { + a.config.init(true); + a.define = window.define; + } + if (!window.ace) + window.ace = a; + for (var key in a) + if (a.hasOwnProperty(key)) + window.ace[key] = a[key]; + }); +})(); \ No newline at end of file diff --git a/modules/discord_desktop_core/core/app/BetterDiscord/index.js b/modules/discord_desktop_core/core/app/BetterDiscord/index.js new file mode 100644 index 0000000..58c59bb --- /dev/null +++ b/modules/discord_desktop_core/core/app/BetterDiscord/index.js @@ -0,0 +1,123 @@ +const ModuleLoader = require("./loaders/modules") +const { EventEmitter } = require("events") +const Logger = require("./Logger") +const fs = require("fs") +const path = require("path") + +const events = exports.events = new EventEmitter() +const logger = exports.logger = new Logger("LightCord") + +let hasInit = false +let tries = 0 + +exports.init = function(){ + if(hasInit == true){ + console.warn(new Error("LightCord has already inited.")) + return + } + hasInit = true + let readyInterval = setInterval(()=>{ + events.emit("debug", `[INIT] try ${tries++} loading LightCord`) + try{ + if(!global.webpackJsonp)return + if(!ModuleLoader.get(4))return + clearInterval(readyInterval) + privateInit() + .then(() => { + console.log("Finished loading Lightcord.") + }) + }catch(e){ + console.error(e) + } + }, 100) +} + +let hasPrivateInit = false + +async function privateInit(){ + if(!hasInit)return + if(hasPrivateInit)return + hasPrivateInit = true + + //disabling sentry + BDModules.get(e => e.getCurrentHub)[0].getCurrentHub().getClient().getOptions().enabled = false + + window.lightcordSettings = { + devMode: false, + callRingingBeat: true + } + + let original = BDModules.get((e) => e.createSound)[0].createSound + BDModules.get((e) => e.createSound)[0].createSound = function(sound){ + let isCalling = sound === "call_ringing_beat" || sound === "call_ringing" + if(isCalling){ + let returned = original(...arguments) + Object.defineProperty(returned, "name", { + get(){ + return window.lightcordSettings.callRingingBeat ? "call_ringing_beat" : "call_ringing" + }, + set(data){ + console.log("Attempting to set call_ringing value. Canceling "+data) + } + }) + console.log(returned) + return returned + }else{ + return original(...arguments) + } + } + + let constants = ModuleLoader.get(m=>m.API_HOST)[0] + let dispatcher = ModuleLoader.get(m=>m.Dispatcher&&m.default&&m.default.dispatch)[0] + require("../../../../../BetterDiscordApp/css/main.css") + require("./lightcord.css") + + + window.$ = window.jQuery = require("./jquery.min.js") + require("./ace.js") + + if(!fs.existsSync(BetterDiscordConfig.dataPath))fs.mkdirSync(BetterDiscordConfig.dataPath, {recursive: true}) + let pluginPath = path.join(BetterDiscordConfig.dataPath, "plugins") + let themePath = path.join(BetterDiscordConfig.dataPath, "themes") + console.log(`Plugins: ${pluginPath}\nThemes: ${themePath}`) + if(!fs.existsSync(pluginPath))fs.mkdirSync(pluginPath, {recursive: true}) + if(!fs.existsSync(themePath))fs.mkdirSync(themePath, {recursive: true}) + + // setting Discord Internal Developer Mode for developement and test purposes. + Object.defineProperty(ModuleLoader.get(e => e.default && typeof e.default === "object" && ("isDeveloper" in e.default))[0].default, "isDeveloper", { + get(){return !!window.lightcordSettings.devMode}, + set(data){return !!window.lightcordSettings.devMode} + }) + + const BetterDiscord = window.BetterDiscord = new(require("../../../../../BetterDiscordApp/js/main").default)(BetterDiscordConfig) + BetterDiscord.init() + + events.emit("ready") +} + +require.extensions[".css"] = (m, filename) => { + let content = fs.readFileSync(filename, "binary") + let style = document.createElement("style") + style.id = btoa(filename) + style.innerText = content + document.head.appendChild(style) + m.exports = { + id: style.id, + remove(){ + return style.remove() + } + } + return m.exports +} + +const BetterDiscordConfig = window.BetterDiscordConfig = { + "local": true, + "localServer": "//localhost:8080", + "repo": "rauenzi", + "branch": "master", + "injectorBranch": "injector", + "minified": true, + "version": "0.3.2", + dataPath: (process.platform == "win32" ? process.env.APPDATA : process.platform == "darwin" ? process.env.HOME + "/Library/Preferences" : process.env.XDG_CONFIG_HOME ? process.env.XDG_CONFIG_HOME : process.env.HOME + "/.config") + "/LightCord_BD/", + os: process.platform +} diff --git a/modules/discord_desktop_core/core/app/BetterDiscord/jquery.min.js b/modules/discord_desktop_core/core/app/BetterDiscord/jquery.min.js new file mode 100644 index 0000000..b18e05a --- /dev/null +++ b/modules/discord_desktop_core/core/app/BetterDiscord/jquery.min.js @@ -0,0 +1,6 @@ +/*! jQuery v2.0.0 | (c) 2005, 2013 jQuery Foundation, Inc. | jquery.org/license +//@ sourceMappingURL=jquery.min.map +*/ +(function(e,undefined){var t,n,r=typeof undefined,i=e.location,o=e.document,s=o.documentElement,a=e.jQuery,u=e.$,l={},c=[],f="2.0.0",p=c.concat,h=c.push,d=c.slice,g=c.indexOf,m=l.toString,y=l.hasOwnProperty,v=f.trim,x=function(e,n){return new x.fn.init(e,n,t)},b=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,w=/\S+/g,T=/^(?:(<[\w\W]+>)[^>]*|#([\w-]*))$/,C=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,k=/^-ms-/,N=/-([\da-z])/gi,E=function(e,t){return t.toUpperCase()},S=function(){o.removeEventListener("DOMContentLoaded",S,!1),e.removeEventListener("load",S,!1),x.ready()};x.fn=x.prototype={jquery:f,constructor:x,init:function(e,t,n){var r,i;if(!e)return this;if("string"==typeof e){if(r="<"===e.charAt(0)&&">"===e.charAt(e.length-1)&&e.length>=3?[null,e,null]:T.exec(e),!r||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof x?t[0]:t,x.merge(this,x.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:o,!0)),C.test(r[1])&&x.isPlainObject(t))for(r in t)x.isFunction(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return i=o.getElementById(r[2]),i&&i.parentNode&&(this.length=1,this[0]=i),this.context=o,this.selector=e,this}return e.nodeType?(this.context=this[0]=e,this.length=1,this):x.isFunction(e)?n.ready(e):(e.selector!==undefined&&(this.selector=e.selector,this.context=e.context),x.makeArray(e,this))},selector:"",length:0,toArray:function(){return d.call(this)},get:function(e){return null==e?this.toArray():0>e?this[this.length+e]:this[e]},pushStack:function(e){var t=x.merge(this.constructor(),e);return t.prevObject=this,t.context=this.context,t},each:function(e,t){return x.each(this,e,t)},ready:function(e){return x.ready.promise().done(e),this},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(0>e?t:0);return this.pushStack(n>=0&&t>n?[this[n]]:[])},map:function(e){return this.pushStack(x.map(this,function(t,n){return e.call(t,n,t)}))},end:function(){return this.prevObject||this.constructor(null)},push:h,sort:[].sort,splice:[].splice},x.fn.init.prototype=x.fn,x.extend=x.fn.extend=function(){var e,t,n,r,i,o,s=arguments[0]||{},a=1,u=arguments.length,l=!1;for("boolean"==typeof s&&(l=s,s=arguments[1]||{},a=2),"object"==typeof s||x.isFunction(s)||(s={}),u===a&&(s=this,--a);u>a;a++)if(null!=(e=arguments[a]))for(t in e)n=s[t],r=e[t],s!==r&&(l&&r&&(x.isPlainObject(r)||(i=x.isArray(r)))?(i?(i=!1,o=n&&x.isArray(n)?n:[]):o=n&&x.isPlainObject(n)?n:{},s[t]=x.extend(l,o,r)):r!==undefined&&(s[t]=r));return s},x.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),noConflict:function(t){return e.$===x&&(e.$=u),t&&e.jQuery===x&&(e.jQuery=a),x},isReady:!1,readyWait:1,holdReady:function(e){e?x.readyWait++:x.ready(!0)},ready:function(e){(e===!0?--x.readyWait:x.isReady)||(x.isReady=!0,e!==!0&&--x.readyWait>0||(n.resolveWith(o,[x]),x.fn.trigger&&x(o).trigger("ready").off("ready")))},isFunction:function(e){return"function"===x.type(e)},isArray:Array.isArray,isWindow:function(e){return null!=e&&e===e.window},isNumeric:function(e){return!isNaN(parseFloat(e))&&isFinite(e)},type:function(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?l[m.call(e)]||"object":typeof e},isPlainObject:function(e){if("object"!==x.type(e)||e.nodeType||x.isWindow(e))return!1;try{if(e.constructor&&!y.call(e.constructor.prototype,"isPrototypeOf"))return!1}catch(t){return!1}return!0},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},error:function(e){throw Error(e)},parseHTML:function(e,t,n){if(!e||"string"!=typeof e)return null;"boolean"==typeof t&&(n=t,t=!1),t=t||o;var r=C.exec(e),i=!n&&[];return r?[t.createElement(r[1])]:(r=x.buildFragment([e],t,i),i&&x(i).remove(),x.merge([],r.childNodes))},parseJSON:JSON.parse,parseXML:function(e){var t,n;if(!e||"string"!=typeof e)return null;try{n=new DOMParser,t=n.parseFromString(e,"text/xml")}catch(r){t=undefined}return(!t||t.getElementsByTagName("parsererror").length)&&x.error("Invalid XML: "+e),t},noop:function(){},globalEval:function(e){var t,n=eval;e=x.trim(e),e&&(1===e.indexOf("use strict")?(t=o.createElement("script"),t.text=e,o.head.appendChild(t).parentNode.removeChild(t)):n(e))},camelCase:function(e){return e.replace(k,"ms-").replace(N,E)},nodeName:function(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()},each:function(e,t,n){var r,i=0,o=e.length,s=j(e);if(n){if(s){for(;o>i;i++)if(r=t.apply(e[i],n),r===!1)break}else for(i in e)if(r=t.apply(e[i],n),r===!1)break}else if(s){for(;o>i;i++)if(r=t.call(e[i],i,e[i]),r===!1)break}else for(i in e)if(r=t.call(e[i],i,e[i]),r===!1)break;return e},trim:function(e){return null==e?"":v.call(e)},makeArray:function(e,t){var n=t||[];return null!=e&&(j(Object(e))?x.merge(n,"string"==typeof e?[e]:e):h.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:g.call(t,e,n)},merge:function(e,t){var n=t.length,r=e.length,i=0;if("number"==typeof n)for(;n>i;i++)e[r++]=t[i];else while(t[i]!==undefined)e[r++]=t[i++];return e.length=r,e},grep:function(e,t,n){var r,i=[],o=0,s=e.length;for(n=!!n;s>o;o++)r=!!t(e[o],o),n!==r&&i.push(e[o]);return i},map:function(e,t,n){var r,i=0,o=e.length,s=j(e),a=[];if(s)for(;o>i;i++)r=t(e[i],i,n),null!=r&&(a[a.length]=r);else for(i in e)r=t(e[i],i,n),null!=r&&(a[a.length]=r);return p.apply([],a)},guid:1,proxy:function(e,t){var n,r,i;return"string"==typeof t&&(n=e[t],t=e,e=n),x.isFunction(e)?(r=d.call(arguments,2),i=function(){return e.apply(t||this,r.concat(d.call(arguments)))},i.guid=e.guid=e.guid||x.guid++,i):undefined},access:function(e,t,n,r,i,o,s){var a=0,u=e.length,l=null==n;if("object"===x.type(n)){i=!0;for(a in n)x.access(e,t,a,n[a],!0,o,s)}else if(r!==undefined&&(i=!0,x.isFunction(r)||(s=!0),l&&(s?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(x(e),n)})),t))for(;u>a;a++)t(e[a],n,s?r:r.call(e[a],a,t(e[a],n)));return i?e:l?t.call(e):u?t(e[0],n):o},now:Date.now,swap:function(e,t,n,r){var i,o,s={};for(o in t)s[o]=e.style[o],e.style[o]=t[o];i=n.apply(e,r||[]);for(o in t)e.style[o]=s[o];return i}}),x.ready.promise=function(t){return n||(n=x.Deferred(),"complete"===o.readyState?setTimeout(x.ready):(o.addEventListener("DOMContentLoaded",S,!1),e.addEventListener("load",S,!1))),n.promise(t)},x.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(e,t){l["[object "+t+"]"]=t.toLowerCase()});function j(e){var t=e.length,n=x.type(e);return x.isWindow(e)?!1:1===e.nodeType&&t?!0:"array"===n||"function"!==n&&(0===t||"number"==typeof t&&t>0&&t-1 in e)}t=x(o),function(e,undefined){var t,n,r,i,o,s,a,u,l,c,f,p,h,d,g,m,y="sizzle"+-new Date,v=e.document,b={},w=0,T=0,C=ot(),k=ot(),N=ot(),E=!1,S=function(){return 0},j=typeof undefined,D=1<<31,A=[],L=A.pop,q=A.push,H=A.push,O=A.slice,F=A.indexOf||function(e){var t=0,n=this.length;for(;n>t;t++)if(this[t]===e)return t;return-1},P="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",R="[\\x20\\t\\r\\n\\f]",M="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",W=M.replace("w","w#"),$="\\["+R+"*("+M+")"+R+"*(?:([*^$|!~]?=)"+R+"*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|("+W+")|)|)"+R+"*\\]",B=":("+M+")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|"+$.replace(3,8)+")*)|.*)\\)|)",I=RegExp("^"+R+"+|((?:^|[^\\\\])(?:\\\\.)*)"+R+"+$","g"),z=RegExp("^"+R+"*,"+R+"*"),_=RegExp("^"+R+"*([>+~]|"+R+")"+R+"*"),X=RegExp(R+"*[+~]"),U=RegExp("="+R+"*([^\\]'\"]*)"+R+"*\\]","g"),Y=RegExp(B),V=RegExp("^"+W+"$"),G={ID:RegExp("^#("+M+")"),CLASS:RegExp("^\\.("+M+")"),TAG:RegExp("^("+M.replace("w","w*")+")"),ATTR:RegExp("^"+$),PSEUDO:RegExp("^"+B),CHILD:RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+R+"*(even|odd|(([+-]|)(\\d*)n|)"+R+"*(?:([+-]|)"+R+"*(\\d+)|))"+R+"*\\)|)","i"),"boolean":RegExp("^(?:"+P+")$","i"),needsContext:RegExp("^"+R+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+R+"*((?:-\\d)?\\d*)"+R+"*\\)|)(?=[^-]|$)","i")},J=/^[^{]+\{\s*\[native \w/,Q=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,K=/^(?:input|select|textarea|button)$/i,Z=/^h\d$/i,et=/'|\\/g,tt=/\\([\da-fA-F]{1,6}[\x20\t\r\n\f]?|.)/g,nt=function(e,t){var n="0x"+t-65536;return n!==n?t:0>n?String.fromCharCode(n+65536):String.fromCharCode(55296|n>>10,56320|1023&n)};try{H.apply(A=O.call(v.childNodes),v.childNodes),A[v.childNodes.length].nodeType}catch(rt){H={apply:A.length?function(e,t){q.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function it(e){return J.test(e+"")}function ot(){var e,t=[];return e=function(n,i){return t.push(n+=" ")>r.cacheLength&&delete e[t.shift()],e[n]=i}}function st(e){return e[y]=!0,e}function at(e){var t=c.createElement("div");try{return!!e(t)}catch(n){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function ut(e,t,n,r){var i,o,s,a,u,f,d,g,x,w;if((t?t.ownerDocument||t:v)!==c&&l(t),t=t||c,n=n||[],!e||"string"!=typeof e)return n;if(1!==(a=t.nodeType)&&9!==a)return[];if(p&&!r){if(i=Q.exec(e))if(s=i[1]){if(9===a){if(o=t.getElementById(s),!o||!o.parentNode)return n;if(o.id===s)return n.push(o),n}else if(t.ownerDocument&&(o=t.ownerDocument.getElementById(s))&&m(t,o)&&o.id===s)return n.push(o),n}else{if(i[2])return H.apply(n,t.getElementsByTagName(e)),n;if((s=i[3])&&b.getElementsByClassName&&t.getElementsByClassName)return H.apply(n,t.getElementsByClassName(s)),n}if(b.qsa&&(!h||!h.test(e))){if(g=d=y,x=t,w=9===a&&e,1===a&&"object"!==t.nodeName.toLowerCase()){f=gt(e),(d=t.getAttribute("id"))?g=d.replace(et,"\\$&"):t.setAttribute("id",g),g="[id='"+g+"'] ",u=f.length;while(u--)f[u]=g+mt(f[u]);x=X.test(e)&&t.parentNode||t,w=f.join(",")}if(w)try{return H.apply(n,x.querySelectorAll(w)),n}catch(T){}finally{d||t.removeAttribute("id")}}}return kt(e.replace(I,"$1"),t,n,r)}o=ut.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return t?"HTML"!==t.nodeName:!1},l=ut.setDocument=function(e){var t=e?e.ownerDocument||e:v;return t!==c&&9===t.nodeType&&t.documentElement?(c=t,f=t.documentElement,p=!o(t),b.getElementsByTagName=at(function(e){return e.appendChild(t.createComment("")),!e.getElementsByTagName("*").length}),b.attributes=at(function(e){return e.className="i",!e.getAttribute("className")}),b.getElementsByClassName=at(function(e){return e.innerHTML="
",e.firstChild.className="i",2===e.getElementsByClassName("i").length}),b.sortDetached=at(function(e){return 1&e.compareDocumentPosition(c.createElement("div"))}),b.getById=at(function(e){return f.appendChild(e).id=y,!t.getElementsByName||!t.getElementsByName(y).length}),b.getById?(r.find.ID=function(e,t){if(typeof t.getElementById!==j&&p){var n=t.getElementById(e);return n&&n.parentNode?[n]:[]}},r.filter.ID=function(e){var t=e.replace(tt,nt);return function(e){return e.getAttribute("id")===t}}):(r.find.ID=function(e,t){if(typeof t.getElementById!==j&&p){var n=t.getElementById(e);return n?n.id===e||typeof n.getAttributeNode!==j&&n.getAttributeNode("id").value===e?[n]:undefined:[]}},r.filter.ID=function(e){var t=e.replace(tt,nt);return function(e){var n=typeof e.getAttributeNode!==j&&e.getAttributeNode("id");return n&&n.value===t}}),r.find.TAG=b.getElementsByTagName?function(e,t){return typeof t.getElementsByTagName!==j?t.getElementsByTagName(e):undefined}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},r.find.CLASS=b.getElementsByClassName&&function(e,t){return typeof t.getElementsByClassName!==j&&p?t.getElementsByClassName(e):undefined},d=[],h=[],(b.qsa=it(t.querySelectorAll))&&(at(function(e){e.innerHTML="",e.querySelectorAll("[selected]").length||h.push("\\["+R+"*(?:value|"+P+")"),e.querySelectorAll(":checked").length||h.push(":checked")}),at(function(e){var t=c.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("t",""),e.querySelectorAll("[t^='']").length&&h.push("[*^$]="+R+"*(?:''|\"\")"),e.querySelectorAll(":enabled").length||h.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),h.push(",.*:")})),(b.matchesSelector=it(g=f.webkitMatchesSelector||f.mozMatchesSelector||f.oMatchesSelector||f.msMatchesSelector))&&at(function(e){b.disconnectedMatch=g.call(e,"div"),g.call(e,"[s!='']:x"),d.push("!=",B)}),h=h.length&&RegExp(h.join("|")),d=d.length&&RegExp(d.join("|")),m=it(f.contains)||f.compareDocumentPosition?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},S=f.compareDocumentPosition?function(e,n){if(e===n)return E=!0,0;var r=n.compareDocumentPosition&&e.compareDocumentPosition&&e.compareDocumentPosition(n);return r?1&r||!b.sortDetached&&n.compareDocumentPosition(e)===r?e===t||m(v,e)?-1:n===t||m(v,n)?1:u?F.call(u,e)-F.call(u,n):0:4&r?-1:1:e.compareDocumentPosition?-1:1}:function(e,n){var r,i=0,o=e.parentNode,s=n.parentNode,a=[e],l=[n];if(e===n)return E=!0,0;if(!o||!s)return e===t?-1:n===t?1:o?-1:s?1:u?F.call(u,e)-F.call(u,n):0;if(o===s)return lt(e,n);r=e;while(r=r.parentNode)a.unshift(r);r=n;while(r=r.parentNode)l.unshift(r);while(a[i]===l[i])i++;return i?lt(a[i],l[i]):a[i]===v?-1:l[i]===v?1:0},c):c},ut.matches=function(e,t){return ut(e,null,null,t)},ut.matchesSelector=function(e,t){if((e.ownerDocument||e)!==c&&l(e),t=t.replace(U,"='$1']"),!(!b.matchesSelector||!p||d&&d.test(t)||h&&h.test(t)))try{var n=g.call(e,t);if(n||b.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(r){}return ut(t,c,null,[e]).length>0},ut.contains=function(e,t){return(e.ownerDocument||e)!==c&&l(e),m(e,t)},ut.attr=function(e,t){(e.ownerDocument||e)!==c&&l(e);var n=r.attrHandle[t.toLowerCase()],i=n&&n(e,t,!p);return i===undefined?b.attributes||!p?e.getAttribute(t):(i=e.getAttributeNode(t))&&i.specified?i.value:null:i},ut.error=function(e){throw Error("Syntax error, unrecognized expression: "+e)},ut.uniqueSort=function(e){var t,n=[],r=0,i=0;if(E=!b.detectDuplicates,u=!b.sortStable&&e.slice(0),e.sort(S),E){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return e};function lt(e,t){var n=t&&e,r=n&&(~t.sourceIndex||D)-(~e.sourceIndex||D);if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function ct(e,t,n){var r;return n?undefined:(r=e.getAttributeNode(t))&&r.specified?r.value:e[t]===!0?t.toLowerCase():null}function ft(e,t,n){var r;return n?undefined:r=e.getAttribute(t,"type"===t.toLowerCase()?1:2)}function pt(e){return function(t){var n=t.nodeName.toLowerCase();return"input"===n&&t.type===e}}function ht(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function dt(e){return st(function(t){return t=+t,st(function(n,r){var i,o=e([],n.length,t),s=o.length;while(s--)n[i=o[s]]&&(n[i]=!(r[i]=n[i]))})})}i=ut.getText=function(e){var t,n="",r=0,o=e.nodeType;if(o){if(1===o||9===o||11===o){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=i(e)}else if(3===o||4===o)return e.nodeValue}else for(;t=e[r];r++)n+=i(t);return n},r=ut.selectors={cacheLength:50,createPseudo:st,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(tt,nt),e[3]=(e[4]||e[5]||"").replace(tt,nt),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||ut.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&ut.error(e[0]),e},PSEUDO:function(e){var t,n=!e[5]&&e[2];return G.CHILD.test(e[0])?null:(e[4]?e[2]=e[4]:n&&Y.test(n)&&(t=gt(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(tt,nt).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=C[e+" "];return t||(t=RegExp("(^|"+R+")"+e+"("+R+"|$)"))&&C(e,function(e){return t.test("string"==typeof e.className&&e.className||typeof e.getAttribute!==j&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=ut.attr(r,e);return null==i?"!="===t:t?(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i+" ").indexOf(n)>-1:"|="===t?i===n||i.slice(0,n.length+1)===n+"-":!1):!0}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),s="last"!==e.slice(-4),a="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,f,p,h,d,g=o!==s?"nextSibling":"previousSibling",m=t.parentNode,v=a&&t.nodeName.toLowerCase(),x=!u&&!a;if(m){if(o){while(g){f=t;while(f=f[g])if(a?f.nodeName.toLowerCase()===v:1===f.nodeType)return!1;d=g="only"===e&&!d&&"nextSibling"}return!0}if(d=[s?m.firstChild:m.lastChild],s&&x){c=m[y]||(m[y]={}),l=c[e]||[],h=l[0]===w&&l[1],p=l[0]===w&&l[2],f=h&&m.childNodes[h];while(f=++h&&f&&f[g]||(p=h=0)||d.pop())if(1===f.nodeType&&++p&&f===t){c[e]=[w,h,p];break}}else if(x&&(l=(t[y]||(t[y]={}))[e])&&l[0]===w)p=l[1];else while(f=++h&&f&&f[g]||(p=h=0)||d.pop())if((a?f.nodeName.toLowerCase()===v:1===f.nodeType)&&++p&&(x&&((f[y]||(f[y]={}))[e]=[w,p]),f===t))break;return p-=i,p===r||0===p%r&&p/r>=0}}},PSEUDO:function(e,t){var n,i=r.pseudos[e]||r.setFilters[e.toLowerCase()]||ut.error("unsupported pseudo: "+e);return i[y]?i(t):i.length>1?(n=[e,e,"",t],r.setFilters.hasOwnProperty(e.toLowerCase())?st(function(e,n){var r,o=i(e,t),s=o.length;while(s--)r=F.call(e,o[s]),e[r]=!(n[r]=o[s])}):function(e){return i(e,0,n)}):i}},pseudos:{not:st(function(e){var t=[],n=[],r=s(e.replace(I,"$1"));return r[y]?st(function(e,t,n,i){var o,s=r(e,null,i,[]),a=e.length;while(a--)(o=s[a])&&(e[a]=!(t[a]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),!n.pop()}}),has:st(function(e){return function(t){return ut(e,t).length>0}}),contains:st(function(e){return function(t){return(t.textContent||t.innerText||i(t)).indexOf(e)>-1}}),lang:st(function(e){return V.test(e||"")||ut.error("unsupported lang: "+e),e=e.replace(tt,nt).toLowerCase(),function(t){var n;do if(n=p?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return n=n.toLowerCase(),n===e||0===n.indexOf(e+"-");while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===f},focus:function(e){return e===c.activeElement&&(!c.hasFocus||c.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:function(e){return e.disabled===!1},disabled:function(e){return e.disabled===!0},checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,e.selected===!0},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeName>"@"||3===e.nodeType||4===e.nodeType)return!1;return!0},parent:function(e){return!r.pseudos.empty(e)},header:function(e){return Z.test(e.nodeName)},input:function(e){return K.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||t.toLowerCase()===e.type)},first:dt(function(){return[0]}),last:dt(function(e,t){return[t-1]}),eq:dt(function(e,t,n){return[0>n?n+t:n]}),even:dt(function(e,t){var n=0;for(;t>n;n+=2)e.push(n);return e}),odd:dt(function(e,t){var n=1;for(;t>n;n+=2)e.push(n);return e}),lt:dt(function(e,t,n){var r=0>n?n+t:n;for(;--r>=0;)e.push(r);return e}),gt:dt(function(e,t,n){var r=0>n?n+t:n;for(;t>++r;)e.push(r);return e})}};for(t in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})r.pseudos[t]=pt(t);for(t in{submit:!0,reset:!0})r.pseudos[t]=ht(t);function gt(e,t){var n,i,o,s,a,u,l,c=k[e+" "];if(c)return t?0:c.slice(0);a=e,u=[],l=r.preFilter;while(a){(!n||(i=z.exec(a)))&&(i&&(a=a.slice(i[0].length)||a),u.push(o=[])),n=!1,(i=_.exec(a))&&(n=i.shift(),o.push({value:n,type:i[0].replace(I," ")}),a=a.slice(n.length));for(s in r.filter)!(i=G[s].exec(a))||l[s]&&!(i=l[s](i))||(n=i.shift(),o.push({value:n,type:s,matches:i}),a=a.slice(n.length));if(!n)break}return t?a.length:a?ut.error(e):k(e,u).slice(0)}function mt(e){var t=0,n=e.length,r="";for(;n>t;t++)r+=e[t].value;return r}function yt(e,t,r){var i=t.dir,o=r&&"parentNode"===i,s=T++;return t.first?function(t,n,r){while(t=t[i])if(1===t.nodeType||o)return e(t,n,r)}:function(t,r,a){var u,l,c,f=w+" "+s;if(a){while(t=t[i])if((1===t.nodeType||o)&&e(t,r,a))return!0}else while(t=t[i])if(1===t.nodeType||o)if(c=t[y]||(t[y]={}),(l=c[i])&&l[0]===f){if((u=l[1])===!0||u===n)return u===!0}else if(l=c[i]=[f],l[1]=e(t,r,a)||n,l[1]===!0)return!0}}function vt(e){return e.length>1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function xt(e,t,n,r,i){var o,s=[],a=0,u=e.length,l=null!=t;for(;u>a;a++)(o=e[a])&&(!n||n(o,r,i))&&(s.push(o),l&&t.push(a));return s}function bt(e,t,n,r,i,o){return r&&!r[y]&&(r=bt(r)),i&&!i[y]&&(i=bt(i,o)),st(function(o,s,a,u){var l,c,f,p=[],h=[],d=s.length,g=o||Ct(t||"*",a.nodeType?[a]:a,[]),m=!e||!o&&t?g:xt(g,p,e,a,u),y=n?i||(o?e:d||r)?[]:s:m;if(n&&n(m,y,a,u),r){l=xt(y,h),r(l,[],a,u),c=l.length;while(c--)(f=l[c])&&(y[h[c]]=!(m[h[c]]=f))}if(o){if(i||e){if(i){l=[],c=y.length;while(c--)(f=y[c])&&l.push(m[c]=f);i(null,y=[],l,u)}c=y.length;while(c--)(f=y[c])&&(l=i?F.call(o,f):p[c])>-1&&(o[l]=!(s[l]=f))}}else y=xt(y===s?y.splice(d,y.length):y),i?i(null,s,y,u):H.apply(s,y)})}function wt(e){var t,n,i,o=e.length,s=r.relative[e[0].type],u=s||r.relative[" "],l=s?1:0,c=yt(function(e){return e===t},u,!0),f=yt(function(e){return F.call(t,e)>-1},u,!0),p=[function(e,n,r){return!s&&(r||n!==a)||((t=n).nodeType?c(e,n,r):f(e,n,r))}];for(;o>l;l++)if(n=r.relative[e[l].type])p=[yt(vt(p),n)];else{if(n=r.filter[e[l].type].apply(null,e[l].matches),n[y]){for(i=++l;o>i;i++)if(r.relative[e[i].type])break;return bt(l>1&&vt(p),l>1&&mt(e.slice(0,l-1)).replace(I,"$1"),n,i>l&&wt(e.slice(l,i)),o>i&&wt(e=e.slice(i)),o>i&&mt(e))}p.push(n)}return vt(p)}function Tt(e,t){var i=0,o=t.length>0,s=e.length>0,u=function(u,l,f,p,h){var d,g,m,y=[],v=0,x="0",b=u&&[],T=null!=h,C=a,k=u||s&&r.find.TAG("*",h&&l.parentNode||l),N=w+=null==C?1:Math.random()||.1;for(T&&(a=l!==c&&l,n=i);null!=(d=k[x]);x++){if(s&&d){g=0;while(m=e[g++])if(m(d,l,f)){p.push(d);break}T&&(w=N,n=++i)}o&&((d=!m&&d)&&v--,u&&b.push(d))}if(v+=x,o&&x!==v){g=0;while(m=t[g++])m(b,y,l,f);if(u){if(v>0)while(x--)b[x]||y[x]||(y[x]=L.call(p));y=xt(y)}H.apply(p,y),T&&!u&&y.length>0&&v+t.length>1&&ut.uniqueSort(p)}return T&&(w=N,a=C),b};return o?st(u):u}s=ut.compile=function(e,t){var n,r=[],i=[],o=N[e+" "];if(!o){t||(t=gt(e)),n=t.length;while(n--)o=wt(t[n]),o[y]?r.push(o):i.push(o);o=N(e,Tt(i,r))}return o};function Ct(e,t,n){var r=0,i=t.length;for(;i>r;r++)ut(e,t[r],n);return n}function kt(e,t,n,i){var o,a,u,l,c,f=gt(e);if(!i&&1===f.length){if(a=f[0]=f[0].slice(0),a.length>2&&"ID"===(u=a[0]).type&&9===t.nodeType&&p&&r.relative[a[1].type]){if(t=(r.find.ID(u.matches[0].replace(tt,nt),t)||[])[0],!t)return n;e=e.slice(a.shift().value.length)}o=G.needsContext.test(e)?0:a.length;while(o--){if(u=a[o],r.relative[l=u.type])break;if((c=r.find[l])&&(i=c(u.matches[0].replace(tt,nt),X.test(a[0].type)&&t.parentNode||t))){if(a.splice(o,1),e=i.length&&mt(a),!e)return H.apply(n,i),n;break}}}return s(e,f)(i,t,!p,n,X.test(e)),n}r.pseudos.nth=r.pseudos.eq;function Nt(){}Nt.prototype=r.filters=r.pseudos,r.setFilters=new Nt,b.sortStable=y.split("").sort(S).join("")===y,l(),[0,0].sort(S),b.detectDuplicates=E,at(function(e){if(e.innerHTML="","#"!==e.firstChild.getAttribute("href")){var t="type|href|height|width".split("|"),n=t.length;while(n--)r.attrHandle[t[n]]=ft}}),at(function(e){if(null!=e.getAttribute("disabled")){var t=P.split("|"),n=t.length;while(n--)r.attrHandle[t[n]]=ct}}),x.find=ut,x.expr=ut.selectors,x.expr[":"]=x.expr.pseudos,x.unique=ut.uniqueSort,x.text=ut.getText,x.isXMLDoc=ut.isXML,x.contains=ut.contains}(e);var D={};function A(e){var t=D[e]={};return x.each(e.match(w)||[],function(e,n){t[n]=!0}),t}x.Callbacks=function(e){e="string"==typeof e?D[e]||A(e):x.extend({},e);var t,n,r,i,o,s,a=[],u=!e.once&&[],l=function(f){for(t=e.memory&&f,n=!0,s=i||0,i=0,o=a.length,r=!0;a&&o>s;s++)if(a[s].apply(f[0],f[1])===!1&&e.stopOnFalse){t=!1;break}r=!1,a&&(u?u.length&&l(u.shift()):t?a=[]:c.disable())},c={add:function(){if(a){var n=a.length;(function s(t){x.each(t,function(t,n){var r=x.type(n);"function"===r?e.unique&&c.has(n)||a.push(n):n&&n.length&&"string"!==r&&s(n)})})(arguments),r?o=a.length:t&&(i=n,l(t))}return this},remove:function(){return a&&x.each(arguments,function(e,t){var n;while((n=x.inArray(t,a,n))>-1)a.splice(n,1),r&&(o>=n&&o--,s>=n&&s--)}),this},has:function(e){return e?x.inArray(e,a)>-1:!(!a||!a.length)},empty:function(){return a=[],o=0,this},disable:function(){return a=u=t=undefined,this},disabled:function(){return!a},lock:function(){return u=undefined,t||c.disable(),this},locked:function(){return!u},fireWith:function(e,t){return t=t||[],t=[e,t.slice?t.slice():t],!a||n&&!u||(r?u.push(t):l(t)),this},fire:function(){return c.fireWith(this,arguments),this},fired:function(){return!!n}};return c},x.extend({Deferred:function(e){var t=[["resolve","done",x.Callbacks("once memory"),"resolved"],["reject","fail",x.Callbacks("once memory"),"rejected"],["notify","progress",x.Callbacks("memory")]],n="pending",r={state:function(){return n},always:function(){return i.done(arguments).fail(arguments),this},then:function(){var e=arguments;return x.Deferred(function(n){x.each(t,function(t,o){var s=o[0],a=x.isFunction(e[t])&&e[t];i[o[1]](function(){var e=a&&a.apply(this,arguments);e&&x.isFunction(e.promise)?e.promise().done(n.resolve).fail(n.reject).progress(n.notify):n[s+"With"](this===r?n.promise():this,a?[e]:arguments)})}),e=null}).promise()},promise:function(e){return null!=e?x.extend(e,r):r}},i={};return r.pipe=r.then,x.each(t,function(e,o){var s=o[2],a=o[3];r[o[1]]=s.add,a&&s.add(function(){n=a},t[1^e][2].disable,t[2][2].lock),i[o[0]]=function(){return i[o[0]+"With"](this===i?r:this,arguments),this},i[o[0]+"With"]=s.fireWith}),r.promise(i),e&&e.call(i,i),i},when:function(e){var t=0,n=d.call(arguments),r=n.length,i=1!==r||e&&x.isFunction(e.promise)?r:0,o=1===i?e:x.Deferred(),s=function(e,t,n){return function(r){t[e]=this,n[e]=arguments.length>1?d.call(arguments):r,n===a?o.notifyWith(t,n):--i||o.resolveWith(t,n)}},a,u,l;if(r>1)for(a=Array(r),u=Array(r),l=Array(r);r>t;t++)n[t]&&x.isFunction(n[t].promise)?n[t].promise().done(s(t,l,n)).fail(o.reject).progress(s(t,u,a)):--i;return i||o.resolveWith(l,n),o.promise()}}),x.support=function(t){var n=o.createElement("input"),r=o.createDocumentFragment(),i=o.createElement("div"),s=o.createElement("select"),a=s.appendChild(o.createElement("option"));return n.type?(n.type="checkbox",t.checkOn=""!==n.value,t.optSelected=a.selected,t.reliableMarginRight=!0,t.boxSizingReliable=!0,t.pixelPosition=!1,n.checked=!0,t.noCloneChecked=n.cloneNode(!0).checked,s.disabled=!0,t.optDisabled=!a.disabled,n=o.createElement("input"),n.value="t",n.type="radio",t.radioValue="t"===n.value,n.setAttribute("checked","t"),n.setAttribute("name","t"),r.appendChild(n),t.checkClone=r.cloneNode(!0).cloneNode(!0).lastChild.checked,t.focusinBubbles="onfocusin"in e,i.style.backgroundClip="content-box",i.cloneNode(!0).style.backgroundClip="",t.clearCloneStyle="content-box"===i.style.backgroundClip,x(function(){var n,r,s="padding:0;margin:0;border:0;display:block;-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box",a=o.getElementsByTagName("body")[0];a&&(n=o.createElement("div"),n.style.cssText="border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px",a.appendChild(n).appendChild(i),i.innerHTML="",i.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%",x.swap(a,null!=a.style.zoom?{zoom:1}:{},function(){t.boxSizing=4===i.offsetWidth}),e.getComputedStyle&&(t.pixelPosition="1%"!==(e.getComputedStyle(i,null)||{}).top,t.boxSizingReliable="4px"===(e.getComputedStyle(i,null)||{width:"4px"}).width,r=i.appendChild(o.createElement("div")),r.style.cssText=i.style.cssText=s,r.style.marginRight=r.style.width="0",i.style.width="1px",t.reliableMarginRight=!parseFloat((e.getComputedStyle(r,null)||{}).marginRight)),a.removeChild(n))}),t):t}({});var L,q,H=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,O=/([A-Z])/g;function F(){Object.defineProperty(this.cache={},0,{get:function(){return{}}}),this.expando=x.expando+Math.random()}F.uid=1,F.accepts=function(e){return e.nodeType?1===e.nodeType||9===e.nodeType:!0},F.prototype={key:function(e){if(!F.accepts(e))return 0;var t={},n=e[this.expando];if(!n){n=F.uid++;try{t[this.expando]={value:n},Object.defineProperties(e,t)}catch(r){t[this.expando]=n,x.extend(e,t)}}return this.cache[n]||(this.cache[n]={}),n},set:function(e,t,n){var r,i=this.key(e),o=this.cache[i];if("string"==typeof t)o[t]=n;else if(x.isEmptyObject(o))this.cache[i]=t;else for(r in t)o[r]=t[r]},get:function(e,t){var n=this.cache[this.key(e)];return t===undefined?n:n[t]},access:function(e,t,n){return t===undefined||t&&"string"==typeof t&&n===undefined?this.get(e,t):(this.set(e,t,n),n!==undefined?n:t)},remove:function(e,t){var n,r,i=this.key(e),o=this.cache[i];if(t===undefined)this.cache[i]={};else{x.isArray(t)?r=t.concat(t.map(x.camelCase)):t in o?r=[t]:(r=x.camelCase(t),r=r in o?[r]:r.match(w)||[]),n=r.length;while(n--)delete o[r[n]]}},hasData:function(e){return!x.isEmptyObject(this.cache[e[this.expando]]||{})},discard:function(e){delete this.cache[this.key(e)]}},L=new F,q=new F,x.extend({acceptData:F.accepts,hasData:function(e){return L.hasData(e)||q.hasData(e)},data:function(e,t,n){return L.access(e,t,n)},removeData:function(e,t){L.remove(e,t)},_data:function(e,t,n){return q.access(e,t,n)},_removeData:function(e,t){q.remove(e,t)}}),x.fn.extend({data:function(e,t){var n,r,i=this[0],o=0,s=null;if(e===undefined){if(this.length&&(s=L.get(i),1===i.nodeType&&!q.get(i,"hasDataAttrs"))){for(n=i.attributes;n.length>o;o++)r=n[o].name,0===r.indexOf("data-")&&(r=x.camelCase(r.substring(5)),P(i,r,s[r]));q.set(i,"hasDataAttrs",!0)}return s}return"object"==typeof e?this.each(function(){L.set(this,e)}):x.access(this,function(t){var n,r=x.camelCase(e);if(i&&t===undefined){if(n=L.get(i,e),n!==undefined)return n;if(n=L.get(i,r),n!==undefined)return n;if(n=P(i,r,undefined),n!==undefined)return n}else this.each(function(){var n=L.get(this,r);L.set(this,r,t),-1!==e.indexOf("-")&&n!==undefined&&L.set(this,e,t)})},null,t,arguments.length>1,null,!0)},removeData:function(e){return this.each(function(){L.remove(this,e)})}});function P(e,t,n){var r;if(n===undefined&&1===e.nodeType)if(r="data-"+t.replace(O,"-$1").toLowerCase(),n=e.getAttribute(r),"string"==typeof n){try{n="true"===n?!0:"false"===n?!1:"null"===n?null:+n+""===n?+n:H.test(n)?JSON.parse(n):n}catch(i){}L.set(e,t,n)}else n=undefined;return n}x.extend({queue:function(e,t,n){var r;return e?(t=(t||"fx")+"queue",r=q.get(e,t),n&&(!r||x.isArray(n)?r=q.access(e,t,x.makeArray(n)):r.push(n)),r||[]):undefined},dequeue:function(e,t){t=t||"fx";var n=x.queue(e,t),r=n.length,i=n.shift(),o=x._queueHooks(e,t),s=function(){x.dequeue(e,t)};"inprogress"===i&&(i=n.shift(),r--),o.cur=i,i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,s,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return q.get(e,n)||q.access(e,n,{empty:x.Callbacks("once memory").add(function(){q.remove(e,[t+"queue",n])})})}}),x.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),n>arguments.length?x.queue(this[0],e):t===undefined?this:this.each(function(){var n=x.queue(this,e,t); +x._queueHooks(this,e),"fx"===e&&"inprogress"!==n[0]&&x.dequeue(this,e)})},dequeue:function(e){return this.each(function(){x.dequeue(this,e)})},delay:function(e,t){return e=x.fx?x.fx.speeds[e]||e:e,t=t||"fx",this.queue(t,function(t,n){var r=setTimeout(t,e);n.stop=function(){clearTimeout(r)}})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=x.Deferred(),o=this,s=this.length,a=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=undefined),e=e||"fx";while(s--)n=q.get(o[s],e+"queueHooks"),n&&n.empty&&(r++,n.empty.add(a));return a(),i.promise(t)}});var R,M,W=/[\t\r\n]/g,$=/\r/g,B=/^(?:input|select|textarea|button)$/i;x.fn.extend({attr:function(e,t){return x.access(this,x.attr,e,t,arguments.length>1)},removeAttr:function(e){return this.each(function(){x.removeAttr(this,e)})},prop:function(e,t){return x.access(this,x.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each(function(){delete this[x.propFix[e]||e]})},addClass:function(e){var t,n,r,i,o,s=0,a=this.length,u="string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).addClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];a>s;s++)if(n=this[s],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(W," "):" ")){o=0;while(i=t[o++])0>r.indexOf(" "+i+" ")&&(r+=i+" ");n.className=x.trim(r)}return this},removeClass:function(e){var t,n,r,i,o,s=0,a=this.length,u=0===arguments.length||"string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).removeClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];a>s;s++)if(n=this[s],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(W," "):"")){o=0;while(i=t[o++])while(r.indexOf(" "+i+" ")>=0)r=r.replace(" "+i+" "," ");n.className=e?x.trim(r):""}return this},toggleClass:function(e,t){var n=typeof e,i="boolean"==typeof t;return x.isFunction(e)?this.each(function(n){x(this).toggleClass(e.call(this,n,this.className,t),t)}):this.each(function(){if("string"===n){var o,s=0,a=x(this),u=t,l=e.match(w)||[];while(o=l[s++])u=i?u:!a.hasClass(o),a[u?"addClass":"removeClass"](o)}else(n===r||"boolean"===n)&&(this.className&&q.set(this,"__className__",this.className),this.className=this.className||e===!1?"":q.get(this,"__className__")||"")})},hasClass:function(e){var t=" "+e+" ",n=0,r=this.length;for(;r>n;n++)if(1===this[n].nodeType&&(" "+this[n].className+" ").replace(W," ").indexOf(t)>=0)return!0;return!1},val:function(e){var t,n,r,i=this[0];{if(arguments.length)return r=x.isFunction(e),this.each(function(n){var i,o=x(this);1===this.nodeType&&(i=r?e.call(this,n,o.val()):e,null==i?i="":"number"==typeof i?i+="":x.isArray(i)&&(i=x.map(i,function(e){return null==e?"":e+""})),t=x.valHooks[this.type]||x.valHooks[this.nodeName.toLowerCase()],t&&"set"in t&&t.set(this,i,"value")!==undefined||(this.value=i))});if(i)return t=x.valHooks[i.type]||x.valHooks[i.nodeName.toLowerCase()],t&&"get"in t&&(n=t.get(i,"value"))!==undefined?n:(n=i.value,"string"==typeof n?n.replace($,""):null==n?"":n)}}}),x.extend({valHooks:{option:{get:function(e){var t=e.attributes.value;return!t||t.specified?e.value:e.text}},select:{get:function(e){var t,n,r=e.options,i=e.selectedIndex,o="select-one"===e.type||0>i,s=o?null:[],a=o?i+1:r.length,u=0>i?a:o?i:0;for(;a>u;u++)if(n=r[u],!(!n.selected&&u!==i||(x.support.optDisabled?n.disabled:null!==n.getAttribute("disabled"))||n.parentNode.disabled&&x.nodeName(n.parentNode,"optgroup"))){if(t=x(n).val(),o)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=x.makeArray(t),s=i.length;while(s--)r=i[s],(r.selected=x.inArray(x(r).val(),o)>=0)&&(n=!0);return n||(e.selectedIndex=-1),o}}},attr:function(e,t,n){var i,o,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return typeof e.getAttribute===r?x.prop(e,t,n):(1===s&&x.isXMLDoc(e)||(t=t.toLowerCase(),i=x.attrHooks[t]||(x.expr.match.boolean.test(t)?M:R)),n===undefined?i&&"get"in i&&null!==(o=i.get(e,t))?o:(o=x.find.attr(e,t),null==o?undefined:o):null!==n?i&&"set"in i&&(o=i.set(e,n,t))!==undefined?o:(e.setAttribute(t,n+""),n):(x.removeAttr(e,t),undefined))},removeAttr:function(e,t){var n,r,i=0,o=t&&t.match(w);if(o&&1===e.nodeType)while(n=o[i++])r=x.propFix[n]||n,x.expr.match.boolean.test(n)&&(e[r]=!1),e.removeAttribute(n)},attrHooks:{type:{set:function(e,t){if(!x.support.radioValue&&"radio"===t&&x.nodeName(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},propFix:{"for":"htmlFor","class":"className"},prop:function(e,t,n){var r,i,o,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return o=1!==s||!x.isXMLDoc(e),o&&(t=x.propFix[t]||t,i=x.propHooks[t]),n!==undefined?i&&"set"in i&&(r=i.set(e,n,t))!==undefined?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){return e.hasAttribute("tabindex")||B.test(e.nodeName)||e.href?e.tabIndex:-1}}}}),M={set:function(e,t,n){return t===!1?x.removeAttr(e,n):e.setAttribute(n,n),n}},x.each(x.expr.match.boolean.source.match(/\w+/g),function(e,t){var n=x.expr.attrHandle[t]||x.find.attr;x.expr.attrHandle[t]=function(e,t,r){var i=x.expr.attrHandle[t],o=r?undefined:(x.expr.attrHandle[t]=undefined)!=n(e,t,r)?t.toLowerCase():null;return x.expr.attrHandle[t]=i,o}}),x.support.optSelected||(x.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null}}),x.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){x.propFix[this.toLowerCase()]=this}),x.each(["radio","checkbox"],function(){x.valHooks[this]={set:function(e,t){return x.isArray(t)?e.checked=x.inArray(x(e).val(),t)>=0:undefined}},x.support.checkOn||(x.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})});var I=/^key/,z=/^(?:mouse|contextmenu)|click/,_=/^(?:focusinfocus|focusoutblur)$/,X=/^([^.]*)(?:\.(.+)|)$/;function U(){return!0}function Y(){return!1}function V(){try{return o.activeElement}catch(e){}}x.event={global:{},add:function(e,t,n,i,o){var s,a,u,l,c,f,p,h,d,g,m,y=q.get(e);if(y){n.handler&&(s=n,n=s.handler,o=s.selector),n.guid||(n.guid=x.guid++),(l=y.events)||(l=y.events={}),(a=y.handle)||(a=y.handle=function(e){return typeof x===r||e&&x.event.triggered===e.type?undefined:x.event.dispatch.apply(a.elem,arguments)},a.elem=e),t=(t||"").match(w)||[""],c=t.length;while(c--)u=X.exec(t[c])||[],d=m=u[1],g=(u[2]||"").split(".").sort(),d&&(p=x.event.special[d]||{},d=(o?p.delegateType:p.bindType)||d,p=x.event.special[d]||{},f=x.extend({type:d,origType:m,data:i,handler:n,guid:n.guid,selector:o,needsContext:o&&x.expr.match.needsContext.test(o),namespace:g.join(".")},s),(h=l[d])||(h=l[d]=[],h.delegateCount=0,p.setup&&p.setup.call(e,i,g,a)!==!1||e.addEventListener&&e.addEventListener(d,a,!1)),p.add&&(p.add.call(e,f),f.handler.guid||(f.handler.guid=n.guid)),o?h.splice(h.delegateCount++,0,f):h.push(f),x.event.global[d]=!0);e=null}},remove:function(e,t,n,r,i){var o,s,a,u,l,c,f,p,h,d,g,m=q.hasData(e)&&q.get(e);if(m&&(u=m.events)){t=(t||"").match(w)||[""],l=t.length;while(l--)if(a=X.exec(t[l])||[],h=g=a[1],d=(a[2]||"").split(".").sort(),h){f=x.event.special[h]||{},h=(r?f.delegateType:f.bindType)||h,p=u[h]||[],a=a[2]&&RegExp("(^|\\.)"+d.join("\\.(?:.*\\.|)")+"(\\.|$)"),s=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||a&&!a.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));s&&!p.length&&(f.teardown&&f.teardown.call(e,d,m.handle)!==!1||x.removeEvent(e,h,m.handle),delete u[h])}else for(h in u)x.event.remove(e,h+t[l],n,r,!0);x.isEmptyObject(u)&&(delete m.handle,q.remove(e,"events"))}},trigger:function(t,n,r,i){var s,a,u,l,c,f,p,h=[r||o],d=y.call(t,"type")?t.type:t,g=y.call(t,"namespace")?t.namespace.split("."):[];if(a=u=r=r||o,3!==r.nodeType&&8!==r.nodeType&&!_.test(d+x.event.triggered)&&(d.indexOf(".")>=0&&(g=d.split("."),d=g.shift(),g.sort()),c=0>d.indexOf(":")&&"on"+d,t=t[x.expando]?t:new x.Event(d,"object"==typeof t&&t),t.isTrigger=i?2:3,t.namespace=g.join("."),t.namespace_re=t.namespace?RegExp("(^|\\.)"+g.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,t.result=undefined,t.target||(t.target=r),n=null==n?[t]:x.makeArray(n,[t]),p=x.event.special[d]||{},i||!p.trigger||p.trigger.apply(r,n)!==!1)){if(!i&&!p.noBubble&&!x.isWindow(r)){for(l=p.delegateType||d,_.test(l+d)||(a=a.parentNode);a;a=a.parentNode)h.push(a),u=a;u===(r.ownerDocument||o)&&h.push(u.defaultView||u.parentWindow||e)}s=0;while((a=h[s++])&&!t.isPropagationStopped())t.type=s>1?l:p.bindType||d,f=(q.get(a,"events")||{})[t.type]&&q.get(a,"handle"),f&&f.apply(a,n),f=c&&a[c],f&&x.acceptData(a)&&f.apply&&f.apply(a,n)===!1&&t.preventDefault();return t.type=d,i||t.isDefaultPrevented()||p._default&&p._default.apply(h.pop(),n)!==!1||!x.acceptData(r)||c&&x.isFunction(r[d])&&!x.isWindow(r)&&(u=r[c],u&&(r[c]=null),x.event.triggered=d,r[d](),x.event.triggered=undefined,u&&(r[c]=u)),t.result}},dispatch:function(e){e=x.event.fix(e);var t,n,r,i,o,s=[],a=d.call(arguments),u=(q.get(this,"events")||{})[e.type]||[],l=x.event.special[e.type]||{};if(a[0]=e,e.delegateTarget=this,!l.preDispatch||l.preDispatch.call(this,e)!==!1){s=x.event.handlers.call(this,e,u),t=0;while((i=s[t++])&&!e.isPropagationStopped()){e.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!e.isImmediatePropagationStopped())(!e.namespace_re||e.namespace_re.test(o.namespace))&&(e.handleObj=o,e.data=o.data,r=((x.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,a),r!==undefined&&(e.result=r)===!1&&(e.preventDefault(),e.stopPropagation()))}return l.postDispatch&&l.postDispatch.call(this,e),e.result}},handlers:function(e,t){var n,r,i,o,s=[],a=t.delegateCount,u=e.target;if(a&&u.nodeType&&(!e.button||"click"!==e.type))for(;u!==this;u=u.parentNode||this)if(u.disabled!==!0||"click"!==e.type){for(r=[],n=0;a>n;n++)o=t[n],i=o.selector+" ",r[i]===undefined&&(r[i]=o.needsContext?x(i,this).index(u)>=0:x.find(i,this,null,[u]).length),r[i]&&r.push(o);r.length&&s.push({elem:u,handlers:r})}return t.length>a&&s.push({elem:this,handlers:t.slice(a)}),s},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(e,t){return null==e.which&&(e.which=null!=t.charCode?t.charCode:t.keyCode),e}},mouseHooks:{props:"button buttons clientX clientY offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(e,t){var n,r,i,s=t.button;return null==e.pageX&&null!=t.clientX&&(n=e.target.ownerDocument||o,r=n.documentElement,i=n.body,e.pageX=t.clientX+(r&&r.scrollLeft||i&&i.scrollLeft||0)-(r&&r.clientLeft||i&&i.clientLeft||0),e.pageY=t.clientY+(r&&r.scrollTop||i&&i.scrollTop||0)-(r&&r.clientTop||i&&i.clientTop||0)),e.which||s===undefined||(e.which=1&s?1:2&s?3:4&s?2:0),e}},fix:function(e){if(e[x.expando])return e;var t,n,r,i=e.type,o=e,s=this.fixHooks[i];s||(this.fixHooks[i]=s=z.test(i)?this.mouseHooks:I.test(i)?this.keyHooks:{}),r=s.props?this.props.concat(s.props):this.props,e=new x.Event(o),t=r.length;while(t--)n=r[t],e[n]=o[n];return 3===e.target.nodeType&&(e.target=e.target.parentNode),s.filter?s.filter(e,o):e},special:{load:{noBubble:!0},focus:{trigger:function(){return this!==V()&&this.focus?(this.focus(),!1):undefined},delegateType:"focusin"},blur:{trigger:function(){return this===V()&&this.blur?(this.blur(),!1):undefined},delegateType:"focusout"},click:{trigger:function(){return"checkbox"===this.type&&this.click&&x.nodeName(this,"input")?(this.click(),!1):undefined},_default:function(e){return x.nodeName(e.target,"a")}},beforeunload:{postDispatch:function(e){e.result!==undefined&&(e.originalEvent.returnValue=e.result)}}},simulate:function(e,t,n,r){var i=x.extend(new x.Event,n,{type:e,isSimulated:!0,originalEvent:{}});r?x.event.trigger(i,null,t):x.event.dispatch.call(t,i),i.isDefaultPrevented()&&n.preventDefault()}},x.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n,!1)},x.Event=function(e,t){return this instanceof x.Event?(e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||e.getPreventDefault&&e.getPreventDefault()?U:Y):this.type=e,t&&x.extend(this,t),this.timeStamp=e&&e.timeStamp||x.now(),this[x.expando]=!0,undefined):new x.Event(e,t)},x.Event.prototype={isDefaultPrevented:Y,isPropagationStopped:Y,isImmediatePropagationStopped:Y,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=U,e&&e.preventDefault&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=U,e&&e.stopPropagation&&e.stopPropagation()},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=U,this.stopPropagation()}},x.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(e,t){x.event.special[e]={delegateType:t,bindType:t,handle:function(e){var n,r=this,i=e.relatedTarget,o=e.handleObj;return(!i||i!==r&&!x.contains(r,i))&&(e.type=o.origType,n=o.handler.apply(this,arguments),e.type=t),n}}}),x.support.focusinBubbles||x.each({focus:"focusin",blur:"focusout"},function(e,t){var n=0,r=function(e){x.event.simulate(t,e.target,x.event.fix(e),!0)};x.event.special[t]={setup:function(){0===n++&&o.addEventListener(e,r,!0)},teardown:function(){0===--n&&o.removeEventListener(e,r,!0)}}}),x.fn.extend({on:function(e,t,n,r,i){var o,s;if("object"==typeof e){"string"!=typeof t&&(n=n||t,t=undefined);for(s in e)this.on(s,t,n,e[s],i);return this}if(null==n&&null==r?(r=t,n=t=undefined):null==r&&("string"==typeof t?(r=n,n=undefined):(r=n,n=t,t=undefined)),r===!1)r=Y;else if(!r)return this;return 1===i&&(o=r,r=function(e){return x().off(e),o.apply(this,arguments)},r.guid=o.guid||(o.guid=x.guid++)),this.each(function(){x.event.add(this,e,r,n,t)})},one:function(e,t,n,r){return this.on(e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,x(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return(t===!1||"function"==typeof t)&&(n=t,t=undefined),n===!1&&(n=Y),this.each(function(){x.event.remove(this,e,n,t)})},trigger:function(e,t){return this.each(function(){x.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];return n?x.event.trigger(e,t,n,!0):undefined}});var G=/^.[^:#\[\.,]*$/,J=x.expr.match.needsContext,Q={children:!0,contents:!0,next:!0,prev:!0};x.fn.extend({find:function(e){var t,n,r,i=this.length;if("string"!=typeof e)return t=this,this.pushStack(x(e).filter(function(){for(r=0;i>r;r++)if(x.contains(t[r],this))return!0}));for(n=[],r=0;i>r;r++)x.find(e,this[r],n);return n=this.pushStack(i>1?x.unique(n):n),n.selector=(this.selector?this.selector+" ":"")+e,n},has:function(e){var t=x(e,this),n=t.length;return this.filter(function(){var e=0;for(;n>e;e++)if(x.contains(this,t[e]))return!0})},not:function(e){return this.pushStack(Z(this,e||[],!0))},filter:function(e){return this.pushStack(Z(this,e||[],!1))},is:function(e){return!!e&&("string"==typeof e?J.test(e)?x(e,this.context).index(this[0])>=0:x.filter(e,this).length>0:this.filter(e).length>0)},closest:function(e,t){var n,r=0,i=this.length,o=[],s=J.test(e)||"string"!=typeof e?x(e,t||this.context):0;for(;i>r;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(11>n.nodeType&&(s?s.index(n)>-1:1===n.nodeType&&x.find.matchesSelector(n,e))){n=o.push(n);break}return this.pushStack(o.length>1?x.unique(o):o)},index:function(e){return e?"string"==typeof e?g.call(x(e),this[0]):g.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){var n="string"==typeof e?x(e,t):x.makeArray(e&&e.nodeType?[e]:e),r=x.merge(this.get(),n);return this.pushStack(x.unique(r))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function K(e,t){while((e=e[t])&&1!==e.nodeType);return e}x.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return x.dir(e,"parentNode")},parentsUntil:function(e,t,n){return x.dir(e,"parentNode",n)},next:function(e){return K(e,"nextSibling")},prev:function(e){return K(e,"previousSibling")},nextAll:function(e){return x.dir(e,"nextSibling")},prevAll:function(e){return x.dir(e,"previousSibling")},nextUntil:function(e,t,n){return x.dir(e,"nextSibling",n)},prevUntil:function(e,t,n){return x.dir(e,"previousSibling",n)},siblings:function(e){return x.sibling((e.parentNode||{}).firstChild,e)},children:function(e){return x.sibling(e.firstChild)},contents:function(e){return x.nodeName(e,"iframe")?e.contentDocument||e.contentWindow.document:x.merge([],e.childNodes)}},function(e,t){x.fn[e]=function(n,r){var i=x.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=x.filter(r,i)),this.length>1&&(Q[e]||x.unique(i),"p"===e[0]&&i.reverse()),this.pushStack(i)}}),x.extend({filter:function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?x.find.matchesSelector(r,e)?[r]:[]:x.find.matches(e,x.grep(t,function(e){return 1===e.nodeType}))},dir:function(e,t,n){var r=[],i=n!==undefined;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&x(e).is(n))break;r.push(e)}return r},sibling:function(e,t){var n=[];for(;e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n}});function Z(e,t,n){if(x.isFunction(t))return x.grep(e,function(e,r){return!!t.call(e,r,e)!==n});if(t.nodeType)return x.grep(e,function(e){return e===t!==n});if("string"==typeof t){if(G.test(t))return x.filter(t,e,n);t=x.filter(t,e)}return x.grep(e,function(e){return g.call(t,e)>=0!==n})}var et=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,tt=/<([\w:]+)/,nt=/<|&#?\w+;/,rt=/<(?:script|style|link)/i,it=/^(?:checkbox|radio)$/i,ot=/checked\s*(?:[^=]|=\s*.checked.)/i,st=/^$|\/(?:java|ecma)script/i,at=/^true\/(.*)/,ut=/^\s*\s*$/g,lt={option:[1,""],thead:[1,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};lt.optgroup=lt.option,lt.tbody=lt.tfoot=lt.colgroup=lt.caption=lt.col=lt.thead,lt.th=lt.td,x.fn.extend({text:function(e){return x.access(this,function(e){return e===undefined?x.text(this):this.empty().append((this[0]&&this[0].ownerDocument||o).createTextNode(e))},null,e,arguments.length)},append:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=ct(this,e);t.appendChild(e)}})},prepend:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=ct(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},remove:function(e,t){var n,r=e?x.filter(e,this):this,i=0;for(;null!=(n=r[i]);i++)t||1!==n.nodeType||x.cleanData(gt(n)),n.parentNode&&(t&&x.contains(n.ownerDocument,n)&&ht(gt(n,"script")),n.parentNode.removeChild(n));return this},empty:function(){var e,t=0;for(;null!=(e=this[t]);t++)1===e.nodeType&&(x.cleanData(gt(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null==e?!1:e,t=null==t?e:t,this.map(function(){return x.clone(this,e,t)})},html:function(e){return x.access(this,function(e){var t=this[0]||{},n=0,r=this.length;if(e===undefined&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!rt.test(e)&&!lt[(tt.exec(e)||["",""])[1].toLowerCase()]){e=e.replace(et,"<$1>");try{for(;r>n;n++)t=this[n]||{},1===t.nodeType&&(x.cleanData(gt(t,!1)),t.innerHTML=e);t=0}catch(i){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var e=x.map(this,function(e){return[e.nextSibling,e.parentNode]}),t=0;return this.domManip(arguments,function(n){var r=e[t++],i=e[t++];i&&(x(this).remove(),i.insertBefore(n,r))},!0),t?this:this.remove()},detach:function(e){return this.remove(e,!0)},domManip:function(e,t,n){e=p.apply([],e);var r,i,o,s,a,u,l=0,c=this.length,f=this,h=c-1,d=e[0],g=x.isFunction(d);if(g||!(1>=c||"string"!=typeof d||x.support.checkClone)&&ot.test(d))return this.each(function(r){var i=f.eq(r);g&&(e[0]=d.call(this,r,i.html())),i.domManip(e,t,n)});if(c&&(r=x.buildFragment(e,this[0].ownerDocument,!1,!n&&this),i=r.firstChild,1===r.childNodes.length&&(r=i),i)){for(o=x.map(gt(r,"script"),ft),s=o.length;c>l;l++)a=r,l!==h&&(a=x.clone(a,!0,!0),s&&x.merge(o,gt(a,"script"))),t.call(this[l],a,l);if(s)for(u=o[o.length-1].ownerDocument,x.map(o,pt),l=0;s>l;l++)a=o[l],st.test(a.type||"")&&!q.access(a,"globalEval")&&x.contains(u,a)&&(a.src?x._evalUrl(a.src):x.globalEval(a.textContent.replace(ut,"")))}return this}}),x.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,t){x.fn[e]=function(e){var n,r=[],i=x(e),o=i.length-1,s=0;for(;o>=s;s++)n=s===o?this:this.clone(!0),x(i[s])[t](n),h.apply(r,n.get());return this.pushStack(r)}}),x.extend({clone:function(e,t,n){var r,i,o,s,a=e.cloneNode(!0),u=x.contains(e.ownerDocument,e);if(!(x.support.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||x.isXMLDoc(e)))for(s=gt(a),o=gt(e),r=0,i=o.length;i>r;r++)mt(o[r],s[r]);if(t)if(n)for(o=o||gt(e),s=s||gt(a),r=0,i=o.length;i>r;r++)dt(o[r],s[r]);else dt(e,a);return s=gt(a,"script"),s.length>0&&ht(s,!u&>(e,"script")),a},buildFragment:function(e,t,n,r){var i,o,s,a,u,l,c=0,f=e.length,p=t.createDocumentFragment(),h=[];for(;f>c;c++)if(i=e[c],i||0===i)if("object"===x.type(i))x.merge(h,i.nodeType?[i]:i);else if(nt.test(i)){o=o||p.appendChild(t.createElement("div")),s=(tt.exec(i)||["",""])[1].toLowerCase(),a=lt[s]||lt._default,o.innerHTML=a[1]+i.replace(et,"<$1>")+a[2],l=a[0];while(l--)o=o.firstChild;x.merge(h,o.childNodes),o=p.firstChild,o.textContent=""}else h.push(t.createTextNode(i));p.textContent="",c=0;while(i=h[c++])if((!r||-1===x.inArray(i,r))&&(u=x.contains(i.ownerDocument,i),o=gt(p.appendChild(i),"script"),u&&ht(o),n)){l=0;while(i=o[l++])st.test(i.type||"")&&n.push(i)}return p},cleanData:function(e){var t,n,r,i=e.length,o=0,s=x.event.special;for(;i>o;o++){if(n=e[o],x.acceptData(n)&&(t=q.access(n)))for(r in t.events)s[r]?x.event.remove(n,r):x.removeEvent(n,r,t.handle);L.discard(n),q.discard(n)}},_evalUrl:function(e){return x.ajax({url:e,type:"GET",dataType:"text",async:!1,global:!1,success:x.globalEval})}});function ct(e,t){return x.nodeName(e,"table")&&x.nodeName(1===t.nodeType?t:t.firstChild,"tr")?e.getElementsByTagName("tbody")[0]||e.appendChild(e.ownerDocument.createElement("tbody")):e}function ft(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function pt(e){var t=at.exec(e.type);return t?e.type=t[1]:e.removeAttribute("type"),e}function ht(e,t){var n=e.length,r=0;for(;n>r;r++)q.set(e[r],"globalEval",!t||q.get(t[r],"globalEval"))}function dt(e,t){var n,r,i,o,s,a,u,l;if(1===t.nodeType){if(q.hasData(e)&&(o=q.access(e),s=x.extend({},o),l=o.events,q.set(t,s),l)){delete s.handle,s.events={};for(i in l)for(n=0,r=l[i].length;r>n;n++)x.event.add(t,i,l[i][n])}L.hasData(e)&&(a=L.access(e),u=x.extend({},a),L.set(t,u))}}function gt(e,t){var n=e.getElementsByTagName?e.getElementsByTagName(t||"*"):e.querySelectorAll?e.querySelectorAll(t||"*"):[];return t===undefined||t&&x.nodeName(e,t)?x.merge([e],n):n}function mt(e,t){var n=t.nodeName.toLowerCase();"input"===n&&it.test(e.type)?t.checked=e.checked:("input"===n||"textarea"===n)&&(t.defaultValue=e.defaultValue)}x.fn.extend({wrapAll:function(e){var t;return x.isFunction(e)?this.each(function(t){x(this).wrapAll(e.call(this,t))}):(this[0]&&(t=x(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this)},wrapInner:function(e){return x.isFunction(e)?this.each(function(t){x(this).wrapInner(e.call(this,t))}):this.each(function(){var t=x(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)})},wrap:function(e){var t=x.isFunction(e);return this.each(function(n){x(this).wrapAll(t?e.call(this,n):e)})},unwrap:function(){return this.parent().each(function(){x.nodeName(this,"body")||x(this).replaceWith(this.childNodes)}).end()}});var yt,vt,xt=/^(none|table(?!-c[ea]).+)/,bt=/^margin/,wt=RegExp("^("+b+")(.*)$","i"),Tt=RegExp("^("+b+")(?!px)[a-z%]+$","i"),Ct=RegExp("^([+-])=("+b+")","i"),kt={BODY:"block"},Nt={position:"absolute",visibility:"hidden",display:"block"},Et={letterSpacing:0,fontWeight:400},St=["Top","Right","Bottom","Left"],jt=["Webkit","O","Moz","ms"];function Dt(e,t){if(t in e)return t;var n=t.charAt(0).toUpperCase()+t.slice(1),r=t,i=jt.length;while(i--)if(t=jt[i]+n,t in e)return t;return r}function At(e,t){return e=t||e,"none"===x.css(e,"display")||!x.contains(e.ownerDocument,e)}function Lt(t){return e.getComputedStyle(t,null)}function qt(e,t){var n,r,i,o=[],s=0,a=e.length;for(;a>s;s++)r=e[s],r.style&&(o[s]=q.get(r,"olddisplay"),n=r.style.display,t?(o[s]||"none"!==n||(r.style.display=""),""===r.style.display&&At(r)&&(o[s]=q.access(r,"olddisplay",Pt(r.nodeName)))):o[s]||(i=At(r),(n&&"none"!==n||!i)&&q.set(r,"olddisplay",i?n:x.css(r,"display"))));for(s=0;a>s;s++)r=e[s],r.style&&(t&&"none"!==r.style.display&&""!==r.style.display||(r.style.display=t?o[s]||"":"none"));return e}x.fn.extend({css:function(e,t){return x.access(this,function(e,t,n){var r,i,o={},s=0;if(x.isArray(t)){for(r=Lt(e),i=t.length;i>s;s++)o[t[s]]=x.css(e,t[s],!1,r);return o}return n!==undefined?x.style(e,t,n):x.css(e,t)},e,t,arguments.length>1)},show:function(){return qt(this,!0)},hide:function(){return qt(this)},toggle:function(e){var t="boolean"==typeof e;return this.each(function(){(t?e:At(this))?x(this).show():x(this).hide()})}}),x.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=yt(e,"opacity");return""===n?"1":n}}}},cssNumber:{columnCount:!0,fillOpacity:!0,fontWeight:!0,lineHeight:!0,opacity:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":"cssFloat"},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,s,a=x.camelCase(t),u=e.style;return t=x.cssProps[a]||(x.cssProps[a]=Dt(u,a)),s=x.cssHooks[t]||x.cssHooks[a],n===undefined?s&&"get"in s&&(i=s.get(e,!1,r))!==undefined?i:u[t]:(o=typeof n,"string"===o&&(i=Ct.exec(n))&&(n=(i[1]+1)*i[2]+parseFloat(x.css(e,t)),o="number"),null==n||"number"===o&&isNaN(n)||("number"!==o||x.cssNumber[a]||(n+="px"),x.support.clearCloneStyle||""!==n||0!==t.indexOf("background")||(u[t]="inherit"),s&&"set"in s&&(n=s.set(e,n,r))===undefined||(u[t]=n)),undefined)}},css:function(e,t,n,r){var i,o,s,a=x.camelCase(t);return t=x.cssProps[a]||(x.cssProps[a]=Dt(e.style,a)),s=x.cssHooks[t]||x.cssHooks[a],s&&"get"in s&&(i=s.get(e,!0,n)),i===undefined&&(i=yt(e,t,r)),"normal"===i&&t in Et&&(i=Et[t]),""===n||n?(o=parseFloat(i),n===!0||x.isNumeric(o)?o||0:i):i}}),yt=function(e,t,n){var r,i,o,s=n||Lt(e),a=s?s.getPropertyValue(t)||s[t]:undefined,u=e.style;return s&&(""!==a||x.contains(e.ownerDocument,e)||(a=x.style(e,t)),Tt.test(a)&&bt.test(t)&&(r=u.width,i=u.minWidth,o=u.maxWidth,u.minWidth=u.maxWidth=u.width=a,a=s.width,u.width=r,u.minWidth=i,u.maxWidth=o)),a};function Ht(e,t,n){var r=wt.exec(t);return r?Math.max(0,r[1]-(n||0))+(r[2]||"px"):t}function Ot(e,t,n,r,i){var o=n===(r?"border":"content")?4:"width"===t?1:0,s=0;for(;4>o;o+=2)"margin"===n&&(s+=x.css(e,n+St[o],!0,i)),r?("content"===n&&(s-=x.css(e,"padding"+St[o],!0,i)),"margin"!==n&&(s-=x.css(e,"border"+St[o]+"Width",!0,i))):(s+=x.css(e,"padding"+St[o],!0,i),"padding"!==n&&(s+=x.css(e,"border"+St[o]+"Width",!0,i)));return s}function Ft(e,t,n){var r=!0,i="width"===t?e.offsetWidth:e.offsetHeight,o=Lt(e),s=x.support.boxSizing&&"border-box"===x.css(e,"boxSizing",!1,o);if(0>=i||null==i){if(i=yt(e,t,o),(0>i||null==i)&&(i=e.style[t]),Tt.test(i))return i;r=s&&(x.support.boxSizingReliable||i===e.style[t]),i=parseFloat(i)||0}return i+Ot(e,t,n||(s?"border":"content"),r,o)+"px"}function Pt(e){var t=o,n=kt[e];return n||(n=Rt(e,t),"none"!==n&&n||(vt=(vt||x("