Lightcord/LightcordApi/js/main.js

2358 lines
254 KiB
JavaScript

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.ts");
/******/ })
/************************************************************************/
/******/ ({
/***/ "./src/alias/react-dom.ts":
/*!********************************!*\
!*** ./src/alias/react-dom.ts ***!
\********************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
module.exports = window["Reac" + "tDOM"];
/***/ }),
/***/ "./src/components/components.ts":
/*!**************************************!*\
!*** ./src/components/components.ts ***!
\**************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const Button_1 = __webpack_require__(/*! ./inputs/Button */ "./src/components/inputs/Button.tsx");
const Switch_1 = __webpack_require__(/*! ./inputs/Switch */ "./src/components/inputs/Switch.tsx");
const RadioGroup_1 = __webpack_require__(/*! ./inputs/RadioGroup */ "./src/components/inputs/RadioGroup.tsx");
const TextArea_1 = __webpack_require__(/*! ./inputs/TextArea */ "./src/components/inputs/TextArea.tsx");
const TextInput_1 = __webpack_require__(/*! ./inputs/TextInput */ "./src/components/inputs/TextInput.tsx");
const Dropdown_1 = __webpack_require__(/*! ./inputs/Dropdown */ "./src/components/inputs/Dropdown.tsx");
const Title_1 = __webpack_require__(/*! ./general/Title */ "./src/components/general/Title.tsx");
const SettingsTitle_1 = __webpack_require__(/*! ./general/SettingsTitle */ "./src/components/general/SettingsTitle.tsx");
const Tabs_1 = __webpack_require__(/*! ./general/Tabs */ "./src/components/general/Tabs.tsx");
const SettingSubTitle_1 = __webpack_require__(/*! ./general/SettingSubTitle */ "./src/components/general/SettingSubTitle.tsx");
const CodeBlock_1 = __webpack_require__(/*! ./general/CodeBlock */ "./src/components/general/CodeBlock.tsx");
const cloneNullProto_1 = __webpack_require__(/*! ../modules/cloneNullProto */ "./src/modules/cloneNullProto.ts");
const Tooltip_1 = __webpack_require__(/*! ./general/Tooltip */ "./src/components/general/Tooltip.ts");
const ColorPicker_1 = __webpack_require__(/*! ./inputs/ColorPicker */ "./src/components/inputs/ColorPicker.tsx");
const AlertBox_1 = __webpack_require__(/*! ./general/AlertBox */ "./src/components/general/AlertBox.tsx");
exports.default = cloneNullProto_1.default({
inputs: cloneNullProto_1.default({
Button: Button_1.default,
Switch: Switch_1.default,
Choices: RadioGroup_1.default,
RadioGroup: RadioGroup_1.default,
TextArea: TextArea_1.default,
TextInput: TextInput_1.default,
Dropdown: Dropdown_1.default,
ColorPicker: ColorPicker_1.default
}),
general: cloneNullProto_1.default({
Title: Title_1.default,
SettingsTitle: SettingsTitle_1.default,
SettingSubTitle: SettingSubTitle_1.default,
Tabs: Tabs_1.default,
CodeBlock: CodeBlock_1.default,
Tooltip: Tooltip_1.default,
AlertBox: AlertBox_1.default
})
});
/***/ }),
/***/ "./src/components/general/AlertBox.tsx":
/*!*********************************************!*\
!*** ./src/components/general/AlertBox.tsx ***!
\*********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
let AlertBoxModules;
class AlertBox extends React.Component {
get modules() {
return AlertBoxModules || (AlertBoxModules = [
WebpackLoader_1.default.find(e => e.default && e.default.displayName === "Markdown" && e.default.defaultProps.parser).default
]);
}
render() {
const [Markdown] = this.modules;
let wrap;
let children;
if (typeof this.props.children === "string") {
wrap = Markdown.prototype.render.call({
props: Object.assign({
className: "",
children: this.props.children
}, Markdown.defaultProps)
});
children = wrap.props.children;
}
else {
wrap = Markdown.prototype.render.call({
props: Object.assign({
className: "",
children: ""
}, Markdown.defaultProps)
});
children = this.props.children;
}
wrap.props.children = React.createElement("div", { className: "lc-alert-box lc-alert-box-" + this.props.type },
React.createElement("blockquote", { className: "lc-blockquote" }, children));
return wrap;
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([
{
children: "***Discord's*** **Markdown** _is_ [supported](https://google.com) or you can just insert your own react childs."
}
], [
{
type: "info"
},
{
type: "success"
},
{
type: "warn"
},
{
type: "error"
}
]);
return AllPreviews;
})();
}
}
exports.default = AlertBox;
AlertBox.defaultProps = {
type: "info",
children: null
};
AlertBox.help = {
info: "You can insert markdown (as string) or normal react childs",
warn: "All string will be interpreted as markdown. If you want raw string, pass an array with the string inside."
};
let AllPreviews;
/***/ }),
/***/ "./src/components/general/CodeBlock.tsx":
/*!**********************************************!*\
!*** ./src/components/general/CodeBlock.tsx ***!
\**********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
let CodeBlockModules;
class CodeBlock extends React.Component {
get modules() {
return CodeBlockModules || (CodeBlockModules = [
WebpackLoader_1.default.find(e => e.markup),
WebpackLoader_1.default.find(e => e.messageContent),
WebpackLoader_1.default.find(e => e.scrollbarGhostHairline),
WebpackLoader_1.default.find(e => e.highlight),
WebpackLoader_1.default.find(e => e.marginBottom8)
]);
}
render() {
let [messageModule1, messageModule2, scrollbarModule1, hightlightJS, marginModule1] = this.modules;
const code = this.props.language === "plaintext" ? React.createElement("code", { className: `${scrollbarModule1.scrollbarGhostHairline} hljs` }, this.props.content) : React.createElement("code", { className: `${scrollbarModule1.scrollbarGhostHairline} hljs`, dangerouslySetInnerHTML: { __html: hightlightJS.highlight(this.props.language, this.props.content).value } });
return (React.createElement("div", { className: `${messageModule1.markup} ${messageModule2.messageContent}` },
React.createElement("pre", null, code),
React.createElement("div", { className: marginModule1.marginBottom8 })));
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([
{
content: "console.log(\"Exemple code\")"
}
]);
AllPreviews.push([
{
language: "js"
},
{
language: "plaintext"
},
...CodeBlock.prototype.modules[3].listLanguages().filter(e => e !== "js").map(e => ({ language: e }))
]);
return AllPreviews;
})();
}
}
exports.default = CodeBlock;
CodeBlock.defaultProps = {
language: "plaintext",
content: ""
};
let AllPreviews;
/***/ }),
/***/ "./src/components/general/SettingSubTitle.tsx":
/*!****************************************************!*\
!*** ./src/components/general/SettingSubTitle.tsx ***!
\****************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
let TitleModules;
class SettingSubTitle extends React.Component {
get modules() {
return TitleModules || (TitleModules = [
WebpackLoader_1.default.find(e => typeof e.marginTop60 === "string"),
WebpackLoader_1.default.findByUniqueProperties(["h5"]),
window.Lightcord.Api.WebpackLoader.findByUniqueProperties(["size14"]),
window.Lightcord.Api.WebpackLoader.findByUniqueProperties(["colorStandard"])
]);
}
render() {
let [marginModule, titleModule, sizeModule, colorModule] = this.modules;
let props = this.props;
let className = `${colorModule.colorStandard} ${sizeModule.size14} ${titleModule.h5} ${marginModule.marginBottom4}`;
if (props.className)
className = +" " + props.className;
return React.createElement("h5", { className }, props.children);
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([
{
children: "Exemple title"
}
]);
return AllPreviews;
})();
}
}
exports.default = SettingSubTitle;
SettingSubTitle.defaultProps = {
children: [],
className: ""
};
let AllPreviews;
/***/ }),
/***/ "./src/components/general/SettingsTitle.tsx":
/*!**************************************************!*\
!*** ./src/components/general/SettingsTitle.tsx ***!
\**************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
const Title_1 = __webpack_require__(/*! ./Title */ "./src/components/general/Title.tsx");
let TitleModules;
class SettingsTitle extends React.Component {
constructor(props) {
super(props);
}
get modules() {
return TitleModules || (TitleModules = [
WebpackLoader_1.default.find(e => typeof e.marginTop60 === "string")
]);
}
render() {
let [marginModule] = this.modules;
let props = this.props;
let className = `${marginModule.marginTop60} ${marginModule.marginBottom20}`;
if (props.className)
className = +" " + props.className;
return React.createElement(Title_1.default, { className }, props.children);
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([
{
children: "Exemple title"
}
]);
return AllPreviews;
})();
}
}
exports.default = SettingsTitle;
SettingsTitle.defaultProps = {
children: [""],
className: ""
};
let AllPreviews;
/***/ }),
/***/ "./src/components/general/Tabs.tsx":
/*!*****************************************!*\
!*** ./src/components/general/Tabs.tsx ***!
\*****************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.Tab = void 0;
const noop_1 = __webpack_require__(/*! ../../modules/noop */ "./src/modules/noop.ts");
const Title_1 = __webpack_require__(/*! ./Title */ "./src/components/general/Title.tsx");
class Tabs extends React.Component {
constructor(props) {
super(props);
this.tabsElements = [];
this.state = {
active: this.props.active || null
};
}
get tabs() {
return this.props.tabs || [];
}
changeTab(tab) {
if (tab === this.state.active)
return;
if (this.props.onChange)
this.props.onChange(tab);
this.setState({
active: tab
});
this.tabsElements.forEach(e => e.setActive(tab === e.props.id));
}
render() {
return (React.createElement("div", { className: "lc-tabWrapper", style: this.props.style },
React.createElement("div", { className: "lc-tabnav", style: { flex: "0 1 auto" } }, this.tabs.map(tab => {
return React.createElement(Tab, { TabContainer: this, title: tab.label, id: tab.id, key: btoa(tab.label + ":" + tab.id) });
})),
React.createElement("div", { className: "lc-tab" }, this.props.children)));
}
isActive(tab) {
return this.state.active === tab;
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([
{
children: (React.createElement("div", { style: { marginTop: "20px", marginBottom: "20px" } },
React.createElement("div", { style: {
backgroundColor: "var(--background-primary)",
padding: "30px 30px",
borderRadius: "8px"
}, className: "lc-tab-box-shadow" },
React.createElement(Title_1.default, null, "Preview tabs"))))
}
], [
{
tabs: [
{
label: "Active tab",
id: "1"
},
{
label: "Unactive tab",
id: "2"
}
]
}
], [
{
active: "1"
}
], [
{
onChange: (tabId) => { }
}
]);
return AllPreviews;
})();
}
}
exports.default = Tabs;
Tabs.defaultProps = {
children: null,
tabs: [{ label: "No tabs was passed to <Tabs>.", id: "none" }],
active: null,
onChange: noop_1.default,
style: {}
};
let AllPreviews;
class Tab extends React.Component {
constructor(props) {
super(props);
this.state = {
active: props.TabContainer.isActive(props.id)
};
this.props.TabContainer.tabsElements.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 (React.createElement("div", { className: className, onClick: () => {
this.props.TabContainer.changeTab(this.props.id);
} }, this.props.title));
}
}
exports.Tab = Tab;
/***/ }),
/***/ "./src/components/general/Title.tsx":
/*!******************************************!*\
!*** ./src/components/general/Title.tsx ***!
\******************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
let TitleModules;
class Title extends React.Component {
constructor(props) {
super(props);
}
get modules() {
return TitleModules || (TitleModules = [
WebpackLoader_1.default.find(e => typeof e.colorStandard === "string"),
WebpackLoader_1.default.find(e => typeof e.size32 === "string"),
WebpackLoader_1.default.find(e => typeof e.h2 === "string")
]);
}
render() {
let [colorModule, sizeModule, titleModule] = this.modules;
let props = this.props;
let className = `${colorModule.colorStandard} ${sizeModule.size14} ${titleModule.h2} ${titleModule.defaultColor} ${titleModule.defaultMarginh2}`;
if (props.className)
className += " " + props.className;
return React.createElement("h2", { className }, props.children);
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([
{
children: "Exemple title"
}
]);
return AllPreviews;
})();
}
}
exports.default = Title;
Title.defaultProps = {
children: null,
className: null
};
let AllPreviews;
/***/ }),
/***/ "./src/components/general/Tooltip.ts":
/*!*******************************************!*\
!*** ./src/components/general/Tooltip.ts ***!
\*******************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
const excludeProperties_1 = __webpack_require__(/*! ../../modules/excludeProperties */ "./src/modules/excludeProperties.ts");
let TooltipModules;
class Tooltip extends React.Component {
constructor(props) {
super(props);
}
get modules() {
return TooltipModules || (TooltipModules = [
WebpackLoader_1.default.find(e => e.default && e.default.displayName === "Tooltip")
]);
}
render() {
let [Tooltip] = this.modules;
let props = excludeProperties_1.default(this.props, ["children"]);
return React.createElement(Tooltip.default, props, (data) => {
return React.createElement("div", Object.assign(Object.assign({}, data), { style: {
width: "fit-content",
height: "fit-content"
} }), this.props.children);
});
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([
{
children: React.createElement(window.Lightcord.Api.Components.inputs.Button, {
color: "green",
look: "ghost",
size: "small",
hoverColor: "yellow",
onClick: () => { },
wrapper: false
}, "Hover this button to see the tooltip")
}
]);
AllPreviews.push([
{
text: "Example Tooltip Text"
}
]);
let colors = [];
Tooltip.Colors.forEach(color => {
colors.push({
color: color
});
});
AllPreviews.push(colors);
let positions = [];
Tooltip.Positions.forEach(p => {
positions.push({
position: p
});
});
AllPreviews.push(positions);
return AllPreviews;
})();
}
}
exports.default = Tooltip;
Tooltip.defaultProps = {
children: null,
text: "No text was passed to Tooltip",
position: "top",
color: "brand"
};
Tooltip.Positions = ["top", "left", "right", "bottom"];
Tooltip.Colors = ["black", "grey", "brand", "green", "yellow", "red"];
let AllPreviews;
/***/ }),
/***/ "./src/components/inputs/Button.tsx":
/*!******************************************!*\
!*** ./src/components/inputs/Button.tsx ***!
\******************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
let ButtonModules;
class Button extends React.Component {
constructor(props) {
super(props);
this.state = {
hover: false
};
}
get modules() {
return ButtonModules || (ButtonModules = [
WebpackLoader_1.default.findByUniqueProperties(["_horizontal"]),
WebpackLoader_1.default.findByUniqueProperties(["colorTransparent"]),
WebpackLoader_1.default.findByUniqueProperties(["buttonWrapper"]),
WebpackLoader_1.default.findByUniqueProperties(["ButtonColors"]),
]);
}
render() {
let [flexModule, euhModule1, buttonModule, colorsModule,] = this.modules;
let props = {};
if (this.props) {
if ("color" in this.props) {
props.color = this.props.color;
}
if ("children" in this.props) {
props.children = this.props.children;
}
if ("onClick" in this.props) {
props.onClick = this.props.onClick;
}
if ("wrapper" in this.props) {
props.wrapper = !!this.props.wrapper;
}
if ("look" in this.props) {
props.look = this.props.look;
}
if ("size" in this.props) {
props.size = this.props.size;
}
if ("hoverColor" in this.props) {
props.hoverColor = this.props.hoverColor;
}
if ("disabled" in this.props) {
props.disabled = this.props.disabled;
}
else {
props.disabled = false;
}
}
if (props.color) {
props.color = props.color.toLowerCase();
if (!Button.Colors.includes(props.color)) {
props.color = Button.Colors[0];
}
}
else {
props.color = Button.Colors[0];
}
if (props.look) {
props.look = props.look.toLowerCase();
if (!Button.Looks.includes(props.look)) {
props.look = Button.Looks[0];
}
}
else {
props.look = Button.Looks[0];
}
if (props.size) {
props.size = props.size.toLowerCase();
if (!Button.Sizes.includes(props.size)) {
props.size = Button.Sizes[0];
}
}
else {
props.size = Button.Sizes[0];
}
if (props.hoverColor) {
props.hoverColor = props.hoverColor.toLowerCase();
if (!Button.HoverColors.includes(props.hoverColor)) {
props.hoverColor = Button.HoverColors[0];
}
}
else {
props.hoverColor = Button.HoverColors[0];
}
let buttonSize = props.size ? colorsModule.ButtonSizes[props.size.toUpperCase()] || "" : "";
if (buttonSize)
buttonSize = " " + buttonSize;
let hoverColor = props.hoverColor ? colorsModule.ButtonHovers[props.hoverColor.toUpperCase()] || "" : "";
if (hoverColor)
hoverColor = " " + hoverColor;
props.onClick = typeof props.onClick === "function" ? props.onClick : () => { };
if (typeof props.wrapper !== "boolean")
props.wrapper = true;
let hover = this.state.hover ? euhModule1.hasHover : "";
if (hover)
hover = " " + hover;
let button = React.createElement("button", { type: "button", className: `${flexModule.flexChild} ${euhModule1.button} ${colorsModule.ButtonLooks[props.look.toUpperCase()]} ${colorsModule.ButtonColors[props.color.toUpperCase()]}${buttonSize}${hoverColor}${hover} ${euhModule1.grow}`, style: { flex: "0 1 auto" }, onClick: this.props.onClick, onMouseEnter: (ev) => {
if (!hoverColor)
return;
this.setState({ hover: true });
}, onMouseLeave: (ev) => {
if (!hoverColor)
return;
this.setState({ hover: false });
}, disabled: props.disabled },
React.createElement("div", { className: euhModule1.contents }, props.children));
if (props.wrapper) {
return React.createElement("div", { className: buttonModule.buttonWrapper }, button);
}
return button;
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
let colors = [];
for (let color of Button.Colors) {
colors.push({
color: color
});
}
AllPreviews.push(colors);
let looks = [];
for (let look of Button.Looks) {
looks.push({
look: look
});
}
AllPreviews.push(looks);
let sizes = [];
for (let size of Button.Sizes) {
sizes.push({
size: size
});
}
AllPreviews.push(sizes);
let hovers = [];
for (let hover of Button.HoverColors) {
hovers.push({
hoverColor: hover
});
}
AllPreviews.push(hovers);
AllPreviews.push([{ children: "Test Button" }]);
AllPreviews.push([{ onClick: () => { } }]);
AllPreviews.push([{ wrapper: false }]);
AllPreviews.push([{ disabled: false }, { disabled: true }]);
return AllPreviews;
})();
}
}
exports.default = Button;
Button.Colors = ["brand", "grey", "red", "green", "yellow", "primary", "link", "white", "black", "transparent"];
Button.Looks = ["filled", "inverted", "outlined", "ghost", "link", "blank"];
Button.Sizes = ["small", "medium", "large", "xlarge", "min", "max", "icon", "none"];
Button.HoverColors = ["default", ...Button.Colors];
let AllPreviews;
/***/ }),
/***/ "./src/components/inputs/ColorPicker.tsx":
/*!***********************************************!*\
!*** ./src/components/inputs/ColorPicker.tsx ***!
\***********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const noop_1 = __webpack_require__(/*! ../../modules/noop */ "./src/modules/noop.ts");
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
const Utils_1 = __webpack_require__(/*! ../../modules/Utils */ "./src/modules/Utils.ts");
const Constants = {
defaultColor: 10070709,
baseColors: [
1752220,
3066993,
3447003,
10181046,
15277667,
15844367,
15105570,
15158332,
9807270,
6323595,
1146986,
2067276,
2123412,
7419530,
11342935,
12745742,
11027200,
10038562,
9936031,
5533306
]
};
let ColorPickerModules;
let isFetching = null;
/**
* This componennt needs to be loaded. As a result, you may experience 100-300ms loading the first time.
* Render will return `null` before loaded.
*/
class ColorPicker extends React.PureComponent {
constructor(props) {
super(props);
this.state = {
value: props.value || null,
lastColor: this.props.value
};
this.onChange = this.onChange.bind(this);
}
/** Preload the component. */
static preload() {
if (ColorPicker.prototype.modules[0])
return;
if (isFetching)
return;
new ColorPicker({}).render();
}
onChange(val) {
this.props.onChange(val);
this.setState({
value: val
});
this.forceUpdate();
}
get modules() {
return ColorPickerModules || (ColorPickerModules = [
WebpackLoader_1.default.find(e => e.default && e.default.displayName === "ColorPicker")
]);
}
renderColorPicker() {
let [ColorPickerComponent] = this.modules;
if (!ColorPickerComponent) {
if (isFetching) { // support for multiple color picker
isFetching.then(() => this.forceUpdate());
return null;
}
ColorPickerModules = null;
let resolve;
isFetching = new Promise(res => (resolve = res));
const GuildSettingsRoles = new (WebpackLoader_1.default.find(e => e.default && e.default.displayName && e.default.displayName.includes("GuildSettingsRoles")).default)().render().type;
const settings = GuildSettingsRoles.prototype.renderRoleSettings.call({
props: {
guild: {
roles: [],
id: null,
isOwner: () => false
},
currentUser: {
id: null
}
},
getSelectedRole() {
return {
id: null
};
}
});
const GuildRoleSettings = settings.props.children.type;
let children = GuildRoleSettings.prototype.renderColorPicker.call({
props: {
role: {
id: null,
color: 0
},
locked: false,
everyone: false
}
}).props.children;
children.type(children.props).props.children.type._ctor().then(c => {
this.forceUpdate();
resolve();
});
return null;
}
return React.createElement(ColorPickerComponent.default, { colors: this.props.baseColors, defaultColor: this.props.defaultColor, value: this.state.value, disabled: this.props.disabled, onChange: this.onChange, customColor: this.props.customColor });
}
render() {
if (this.state.lastColor !== this.props.value) {
this.state = {
value: this.props.value,
lastColor: this.props.value
};
}
return this.renderColorPicker();
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([
{
disabled: false
},
{
disabled: true
}
], [
{
value: Utils_1.default.HexColorToDecimal("#7289DA")
}, {
value: null
}
], [
{
onChange: (color) => { }
}
]);
return AllPreviews;
})();
}
}
exports.default = ColorPicker;
ColorPicker.defaultProps = {
defaultColor: Constants.defaultColor,
customColor: null,
baseColors: Constants.baseColors,
value: null,
disabled: false,
onChange: noop_1.default
};
ColorPicker.help = {
info: "To convert hex colors to decimal, you can do `Lightcord.Api.Utils.HexColorToDecimal('#yourcolor')` and go back with `Lightcord.Api.Utils.DecimalColorToHex(7506394)`",
warn: "The component may not appear instantly. The component needs to be loaded, so you could experience 50-300ms loading time depending on your internet connection."
};
let AllPreviews;
/***/ }),
/***/ "./src/components/inputs/Dropdown.tsx":
/*!********************************************!*\
!*** ./src/components/inputs/Dropdown.tsx ***!
\********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const noop_1 = __webpack_require__(/*! ../../modules/noop */ "./src/modules/noop.ts");
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
let DropdownModules;
class Dropdown extends React.Component {
constructor(props) {
super(props);
this.onChange = this.onChange.bind(this);
this.state = {
value: props.value || null
};
}
onChange(value) {
this.props.onChange(value);
this.setState({
value: value
});
}
get modules() {
return DropdownModules || (DropdownModules = [
WebpackLoader_1.default.find(e => e.default && e.default.displayName === "SelectTempWrapper").default
]);
}
render() {
let [DropdownComponent] = this.modules;
let props = this.props;
let returnValue = React.createElement(DropdownComponent, Object.assign({}, props, { onChange: this.onChange, value: this.state.value }));
return returnValue;
}
get value() {
return this.state.value;
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([{
error: null
}, {
error: "An error occured"
}], [{
options: [
{
value: "option1",
label: "Option 1"
},
{
value: "option2",
label: "Option 2"
},
{
value: "option3",
label: "Option 3"
}
]
}], [{
value: "option1"
}], [{
disabled: false
}, {
disabled: true
}], [{
searchable: true
}, {
searchable: false
}], [{
clearable: true
}, {
clearable: false
}], [{
isMulti: false
}, {
isMulti: true
}]);
return AllPreviews;
})();
}
}
exports.default = Dropdown;
Dropdown.defaultProps = {
className: null,
error: null,
options: [{
value: "none",
"label": "No options - No options was passed to Dropdown. If you meant to put an empty dropdown, input an empty array."
}],
valueRenderer: null,
multiValueRenderer: null,
optionRenderer: null,
onChange: noop_1.default,
value: null,
disabled: false,
searchable: false,
clearable: false,
styleOverrides: null,
lightThemeColorOverrides: null,
darkThemeColorOverrides: null,
isMulti: false
};
let AllPreviews;
/***/ }),
/***/ "./src/components/inputs/RadioGroup.tsx":
/*!**********************************************!*\
!*** ./src/components/inputs/RadioGroup.tsx ***!
\**********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const noop_1 = __webpack_require__(/*! ../../modules/noop */ "./src/modules/noop.ts");
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
let RadioGroupModule;
class RadioGroup extends React.Component {
constructor(props) {
super(props);
this.onChange = this.onChange.bind(this);
this.state = {
value: props.value
};
}
onChange(ev) {
this.props.onChange(ev.value);
this.setState({
value: ev.value
});
}
get modules() {
return RadioGroupModule || (RadioGroupModule = [
WebpackLoader_1.default.find(e => e.default && e.default.displayName === "RadioGroup").default
]);
}
render() {
let [RadioGroupComponent] = this.modules;
let props = this.props;
return React.createElement(RadioGroupComponent, { options: props.options, onChange: this.onChange, value: this.state.value, disabled: props.disabled, size: RadioGroupComponent.Sizes[props.size.toUpperCase()], itemType: RadioGroupComponent.ItemTypes[props.itemType.toUpperCase()], infoClassName: props.infoClassName });
}
get value() {
return this.state.value;
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([{
options: [
{
value: "option1",
name: "Option 1",
desc: "description 1"
},
{
value: "option2",
name: "Option 2",
desc: "description 2"
},
{
value: "option3",
name: "Option 3",
desc: "description 3"
}
]
}], [{
value: "option1"
}], [{
disabled: false
}, {
disabled: true
}], [{
size: "medium"
}, {
size: "small"
}], [{
itemType: "bar"
}, {
itemType: "panel"
}]);
return AllPreviews;
})();
}
}
exports.default = RadioGroup;
RadioGroup.defaultProps = {
options: [{
value: "none",
name: "No options",
desc: "No options was passed to Choices. If you meant to display no options at all, please pass an empty array.",
color: "#f04747"
}],
value: null,
disabled: false,
size: "medium",
itemType: "bar",
infoClassName: null,
onChange: noop_1.default
};
let AllPreviews;
/***/ }),
/***/ "./src/components/inputs/Switch.tsx":
/*!******************************************!*\
!*** ./src/components/inputs/Switch.tsx ***!
\******************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
const noop_1 = __webpack_require__(/*! ../../modules/noop */ "./src/modules/noop.ts");
let SwitchModules;
class Switch extends React.Component {
constructor(props) {
super(props);
this.state = {
value: props.value || false
};
this.onChange = this.onChange.bind(this);
}
get modules() {
return SwitchModules || (SwitchModules = [
WebpackLoader_1.default.find(e => e.default && e.default.displayName === "Switch").default
]);
}
render() {
let [SwitchComponent] = this.modules;
let props = this.props;
return (React.createElement(SwitchComponent, { id: props.id, onChange: this.onChange, value: this.state.value || false, fill: props.fill, theme: SwitchComponent.Themes[props.theme.toUpperCase()], disabled: props.disabled, className: props.className, size: SwitchComponent.Sizes[props.size.toUpperCase()], style: props.style }));
}
onChange(value) {
this.props.onChange(!this.state.value);
this.setState({
value: !this.state.value
});
}
get value() {
return this.state.value;
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([{ onChange: (value) => { } }]);
AllPreviews.push([{
value: false
}], [{
theme: "default"
}, {
theme: "clear"
}], [{
disabled: false
}, {
disabled: true
}], [{
id: "api-preview-switch"
}], [{
fill: null
}], [{
size: "default"
}, {
size: "mini"
}], [{
style: {}
}]);
return AllPreviews;
})();
}
}
exports.default = Switch;
Switch.defaultProps = {
id: null,
onChange: noop_1.default,
value: false,
fill: null,
theme: "default",
disabled: false,
className: null,
size: "default",
style: {}
};
Switch.help = {
error: "The `clear` option doesn't work well on light theme."
};
let AllPreviews;
/***/ }),
/***/ "./src/components/inputs/TextArea.tsx":
/*!********************************************!*\
!*** ./src/components/inputs/TextArea.tsx ***!
\********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
const noop_1 = __webpack_require__(/*! ../../modules/noop */ "./src/modules/noop.ts");
let TextAreaModules;
class TextArea extends React.Component {
constructor(props) {
super(props);
this.onChange = this.onChange.bind(this);
this.onFocus = this.onFocus.bind(this);
this.onBlur = this.onBlur.bind(this);
this.onKeyDown = this.onKeyDown.bind(this);
this.state = {
value: props.value || ""
};
}
get modules() {
return TextAreaModules || (TextAreaModules = [
WebpackLoader_1.default.find(e => e.default && e.default.displayName === "TextArea").default
]);
}
onChange(value, name) {
this.props.onChange(value, name);
this.setState({
value
});
}
onFocus(ev, name) {
this.props.onFocus(ev, name);
}
onBlur(ev, name) {
this.props.onBlur(ev, name);
}
onKeyDown(ev) {
this.props.onKeyDown(ev);
}
render() {
let [TextAreaComponent] = this.modules;
let props = this.props;
return React.createElement(TextAreaComponent, Object.assign({}, props, { onChange: this.onChange, onFocus: this.onFocus, onBlur: this.onBlur, onKeyDown: this.onKeyDown, value: this.state.value }));
}
get value() {
return this.state.value || "";
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([{
name: "api-preview-textarea"
}]);
AllPreviews.push([{
disabled: false
}, {
disabled: true
}]);
AllPreviews.push([{
placeholder: null
}]);
AllPreviews.push([{
autoFocus: false
}, {
autoFocus: true
}]);
AllPreviews.push([{
resizeable: false
}, {
resizeable: true
}]);
AllPreviews.push([{
flex: false
}, {
flex: true
}]);
AllPreviews.push([{
autosize: false
}, {
autosize: true
}]);
AllPreviews.push([{
rows: 3
}, {
rows: 2
}, {
rows: 1
}]);
AllPreviews.push([{
value: ""
}]);
AllPreviews.push([{
error: null
}, {
error: "Example error"
}]);
AllPreviews.push([{
maxLength: 100
}]);
AllPreviews.push([{
className: ""
}]);
AllPreviews.push([{
inputClassName: ""
}]);
AllPreviews.push([{
id: "api-preview-textarea"
}]);
return AllPreviews;
})();
}
}
exports.default = TextArea;
TextArea.defaultProps = {
name: null,
disabled: false,
placeholder: null,
autoFocus: false,
resizeable: false,
flex: false,
autosize: false,
rows: 3,
value: "",
error: null,
maxLength: null,
className: null,
id: null,
onChange: noop_1.default,
onFocus: noop_1.default,
onBlur: noop_1.default,
onKeyDown: noop_1.default
};
TextArea.help = {
warn: "This should be used for multi line inputs."
};
let AllPreviews;
/***/ }),
/***/ "./src/components/inputs/TextInput.tsx":
/*!*********************************************!*\
!*** ./src/components/inputs/TextInput.tsx ***!
\*********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
const noop_1 = __webpack_require__(/*! ../../modules/noop */ "./src/modules/noop.ts");
let TextInputModules;
class TextInput extends React.PureComponent {
constructor(props) {
super(props);
this.onChange = this.onChange.bind(this);
this.onFocus = this.onFocus.bind(this);
this.onBlur = this.onBlur.bind(this);
this.state = {
value: props.value || ""
};
}
get modules() {
return TextInputModules || (TextInputModules = [
WebpackLoader_1.default.find(e => e.default && e.default.displayName === "TextInput").default
]);
}
onChange(value, name) {
this.hasSet = false;
this.props.onChange(value, name, this);
if (this.hasSet)
return; // prevent event if the onChange has changed the value.
this.setState({
value
});
this.forceUpdate();
}
onFocus(ev, name) {
this.props.onFocus(ev, name, this);
}
onBlur(ev, name) {
this.props.onBlur(ev, name, this);
}
render() {
let [TextAreaComponent] = this.modules;
let props = this.props;
return React.createElement(TextAreaComponent, Object.assign({}, props, { onChange: this.onChange, onFocus: this.onFocus, onBlur: this.onBlur, value: this.state.value }));
}
get value() {
return this.state.value || "";
}
setValue(value) {
this.setState({
value: value
});
this.forceUpdate();
this.hasSet = true;
}
static get AllPreviews() {
return AllPreviews || (() => {
AllPreviews = [];
AllPreviews.push([{
name: "api-preview-textinput"
}], [{
size: "default"
}, {
size: "mini"
}], [{
disabled: false
}, {
disabled: true
}], [{
placeholder: ""
}], [{
value: ""
}], [{
error: null
}, {
error: "Example error"
}], [{
maxLength: 999
}], [{
className: ""
}], [{
inputClassName: ""
}], [{
id: "api-preview-textinput"
}], [{
onChange: (value, name) => { }
}]);
return AllPreviews;
})();
}
}
exports.default = TextInput;
TextInput.defaultProps = {
name: "",
size: "default",
disabled: false,
placeholder: "",
value: "",
error: null,
maxLength: 999,
className: "",
inputClassName: "",
id: null,
onChange: noop_1.default,
onFocus: noop_1.default,
onBlur: noop_1.default
};
TextInput.help = {
warn: "This should be used for single line inputs."
};
let AllPreviews;
/***/ }),
/***/ "./src/components/private/Notice.tsx":
/*!*******************************************!*\
!*** ./src/components/private/Notice.tsx ***!
\*******************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.defaultNotice = void 0;
const WebpackLoader_1 = __webpack_require__(/*! ../../modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
const Notices_1 = __webpack_require__(/*! ./Notices */ "./src/components/private/Notices.tsx");
const noop_1 = __webpack_require__(/*! ../../modules/noop */ "./src/modules/noop.ts");
let NoticeModules;
exports.defaultNotice = {
text: "",
id: "unknown id",
onClick: noop_1.default,
buttonText: null,
type: "default"
};
class Notice extends React.Component {
get modules() {
return NoticeModules || (NoticeModules = [
WebpackLoader_1.default.find(e => e.noticeInfo)
]);
}
render() {
const [noticeClasses] = this.modules;
const className = noticeClasses["notice" + this.props.type.slice(0, 1).toUpperCase() + this.props.type.slice(1)];
if (!className) {
Notices_1.notices.pop();
setImmediate(() => {
Notices_1.events.emit("noticeUpdate");
});
return null;
}
const button = this.props.buttonText ? React.createElement("button", { className: noticeClasses.button, onClick: () => {
Notices_1.notices.pop();
this.props.onClick();
Notices_1.events.emit("noticeUpdate");
} }, this.props.buttonText) : null;
return React.createElement("div", { className: className },
React.createElement("div", { className: noticeClasses.dismiss, role: "button", tabIndex: 0, onClick: () => {
Notices_1.notices.pop();
Notices_1.events.emit("noticeUpdate");
} }),
this.props.text,
button);
}
}
exports.default = Notice;
Notice.displayName = "LightcordNotice";
Notice.defaultProps = exports.defaultNotice;
/***/ }),
/***/ "./src/components/private/Notices.tsx":
/*!********************************************!*\
!*** ./src/components/private/Notices.tsx ***!
\********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.notices = exports.events = void 0;
const Notice_1 = __webpack_require__(/*! ./Notice */ "./src/components/private/Notice.tsx");
const events_1 = __webpack_require__(/*! events */ "events");
exports.events = new events_1.EventEmitter();
class Notices extends React.Component {
constructor(props) {
super(props);
this.noticeHandler = this.noticeHandler.bind(this);
}
noticeHandler() {
this.forceUpdate();
}
componentWillMount() {
exports.events.on("noticeUpdate", this.noticeHandler);
}
componentWillUnmount() {
exports.events.off("noticeUpdate", this.noticeHandler);
}
render() {
if (!this.hasNotice)
return null;
const notice = exports.notices[0];
return React.createElement(Notice_1.default, Object.assign({}, notice));
}
get hasNotice() {
return exports.notices.length > 0;
}
}
exports.default = Notices;
Notices.displayName = "LightcordNotices";
Notices.defaultProps = {};
exports.notices = [];
/***/ }),
/***/ "./src/index.ts":
/*!**********************!*\
!*** ./src/index.ts ***!
\**********************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const WebpackLoader_1 = __webpack_require__(/*! ./modules/WebpackLoader */ "./src/modules/WebpackLoader.ts");
const components_1 = __webpack_require__(/*! ./components/components */ "./src/components/components.ts");
const uuid_1 = __webpack_require__(/*! ./modules/uuid */ "./src/modules/uuid.ts");
const Utils_1 = __webpack_require__(/*! ./modules/Utils */ "./src/modules/Utils.ts");
const DiscordTools_1 = __webpack_require__(/*! ./modules/DiscordTools */ "./src/modules/DiscordTools.ts");
const patchers = __webpack_require__(/*! ./modules/patchers */ "./src/modules/patchers.ts");
const excludeProperties_1 = __webpack_require__(/*! ./modules/excludeProperties */ "./src/modules/excludeProperties.ts");
const cloneNullProto_1 = __webpack_require__(/*! ./modules/cloneNullProto */ "./src/modules/cloneNullProto.ts");
const noop_1 = __webpack_require__(/*! ./modules/noop */ "./src/modules/noop.ts");
const Unfreeze_1 = __webpack_require__(/*! ./modules/Unfreeze */ "./src/modules/Unfreeze.ts");
patchers.patch();
const LightcordApi = {
WebpackLoader: WebpackLoader_1.default,
Components: components_1.default,
uuid: uuid_1.default,
Utils: Utils_1.default,
DiscordTools: DiscordTools_1.default,
_: {
excludeProperties: excludeProperties_1.default,
cloneNullProto: cloneNullProto_1.default,
NOOP: noop_1.default,
unfreeze: Unfreeze_1.default
}
};
exports.default = LightcordApi;
Object.assign(window.Lightcord.Api, LightcordApi);
/***/ }),
/***/ "./src/modules/DiscordTools.ts":
/*!*************************************!*\
!*** ./src/modules/DiscordTools.ts ***!
\*************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.Notice = void 0;
const Notices_1 = __webpack_require__(/*! ../components/private/Notices */ "./src/components/private/Notices.tsx");
const Utils_1 = __webpack_require__(/*! ./Utils */ "./src/modules/Utils.ts");
const uuid_1 = __webpack_require__(/*! ./uuid */ "./src/modules/uuid.ts");
const cloneNullProto_1 = __webpack_require__(/*! ./cloneNullProto */ "./src/modules/cloneNullProto.ts");
const events_1 = __webpack_require__(/*! events */ "events");
const Notice_1 = __webpack_require__(/*! ../components/private/Notice */ "./src/components/private/Notice.tsx");
const excludeProperties_1 = __webpack_require__(/*! ./excludeProperties */ "./src/modules/excludeProperties.ts");
const noop_1 = __webpack_require__(/*! ./noop */ "./src/modules/noop.ts");
const WebpackLoader_1 = __webpack_require__(/*! ./WebpackLoader */ "./src/modules/WebpackLoader.ts");
let soundModule;
exports.default = new class DiscordTools {
showNotice(data) {
if (typeof data !== "object" || typeof data.text !== "string")
throw new Error(`This notice is not valid. Given: ${Utils_1.default.formatJSObject(data)}`);
let newData = cloneNullProto_1.default(Object.assign({}, Notice_1.defaultNotice, data));
newData.id = uuid_1.default();
Notices_1.notices.push(newData);
Notices_1.events.emit("noticeUpdate");
const notice = new Notice(newData);
return notice;
}
get notices() {
return Notices_1.notices.map(data => new Notice(data));
}
/**
* Quickly send notification (Even when no focused.)
* @param data The notification. Be sure to include all properties except functions cause they're optional.
* Notifications have a timeout of 3-5 seconds.
* They look like this: https://i.imgur.com/jzuxKKu.png
*/
showNotification(data) {
const notification = new window.Notification(data.title, excludeProperties_1.default(data, [
"title",
"onClick",
"onClose",
"onShow"
]));
notification.onclick = data.onClick || noop_1.default;
notification.onshow = data.onShow || noop_1.default;
notification.onclose = data.onClose || noop_1.default;
return notification;
}
createSound(sound) {
soundModule = soundModule || WebpackLoader_1.default.findByUniqueProperties(["createSound"]);
if (!soundModule)
throw new WebpackLoader_1.WebpackLoaderError("Couldn't find soundModule here.");
const created = soundModule.createSound(sound);
return created;
}
playSound(sound) {
const created = this.createSound(sound);
created.play();
return created;
}
};
const EventHandler = function () {
if (this.removed !== this.state.removed) {
if (this.removed) {
this.emit("removed");
}
}
if (this.showing !== this.state.showing) {
if (this.showing) {
this.emit("showing", true);
}
else {
this.emit("showing", false);
}
}
if (this.index !== this.state.index) {
this.emit("index", this.index);
}
};
/** A notice interface for modifying it and subscribing to events. */
class Notice extends events_1.EventEmitter {
constructor(data) {
super();
this.data = data;
this.state = {
removed: this.removed,
showing: this.showing,
index: this.index
};
let eventFunc = EventHandler.bind(this);
Notices_1.events.on("noticeUpdate", eventFunc);
this.on("removed", () => {
Notices_1.events.off("noticeUpdate", eventFunc);
});
}
on(event, listener) {
return super.on(event, listener);
}
once(event, listener) {
return super.once(event, listener);
}
off(event, listener) {
return super.off(event, listener);
}
get removed() {
return !Notices_1.notices.find(e => e.id === this.id);
}
get showing() {
return this.index === 0;
}
get index() {
return Notices_1.notices.findIndex(e => e.id === this.id);
}
get id() {
return this.data.id;
}
get text() {
return this.data.text;
}
set text(text) {
this.data.text = text;
Notices_1.events.emit("noticeUpdate");
}
get type() {
return this.data.type;
}
set type(type) {
this.data.type = type;
Notices_1.events.emit("noticeUpdate");
}
get buttonText() {
return this.data.buttonText;
}
set buttonText(buttonText) {
this.data.buttonText = buttonText;
Notices_1.events.emit("noticeUpdate");
}
get onClick() {
return this.data.onClick;
}
set onClick(onClick) {
this.data.onClick = onClick;
Notices_1.events.emit("noticeUpdate");
}
remove() {
if (this.removed)
return;
Notices_1.notices.splice(this.index, 1);
Notices_1.events.emit("noticeUpdate");
}
}
exports.Notice = Notice;
/***/ }),
/***/ "./src/modules/PluginUtilities.ts":
/*!****************************************!*\
!*** ./src/modules/PluginUtilities.ts ***!
\****************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const components_1 = __webpack_require__(/*! ../components/components */ "./src/components/components.ts");
const Utils_1 = __webpack_require__(/*! ./Utils */ "./src/modules/Utils.ts");
const uuid_1 = __webpack_require__(/*! ./uuid */ "./src/modules/uuid.ts");
const TextInput_1 = __webpack_require__(/*! ../components/inputs/TextInput */ "./src/components/inputs/TextInput.tsx");
exports.default = new class PluginUtilities {
constructor() { }
renderSettings(settings) {
let items = this.renderSettingsToReact(settings);
let elem = React.createElement("div", { key: uuid_1.default() }, items);
return Utils_1.default.ReactToHTMLElement(elem);
}
renderSettingsToReact(settings) {
let items = [];
settings.forEach(item => {
if (typeof item !== "object")
return items.push(item);
if (item.props && "children" in item.props) {
if (!Array.isArray(item.props.children))
item.props.children = [item.props.children];
item.props.children = this.renderSettingsToReact(item.props.children);
}
if (!item.props)
item.props = {};
item.props.key = uuid_1.default();
let component = Utils_1.default.getNestedProps(components_1.default, item.component);
if (!component) {
let warning = new TextInput_1.default({
value: `Warning: No component was found for: "${item.component}". Please correct your code.`,
disabled: true,
error: `Warning: No component was found for: "${item.component}". Please correct your code.`
}).render();
items.push(warning);
return;
}
items.push(React.createElement(component, Object.create(item.props)));
});
return items;
}
};
/***/ }),
/***/ "./src/modules/Unfreeze.ts":
/*!*********************************!*\
!*** ./src/modules/Unfreeze.ts ***!
\*********************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
function unfreeze(o) {
var oo = undefined;
if (o instanceof Array) {
oo = [];
var clone = function (v) {
oo.push(v);
};
o.forEach(clone);
}
else if (o instanceof String) {
oo = new String(o).toString();
}
else if (typeof o == 'object') {
oo = {};
for (var property in o) {
oo[property] = o[property];
}
}
return oo;
}
exports.default = unfreeze;
Object.unfreeze = unfreeze;
/***/ }),
/***/ "./src/modules/Utils.ts":
/*!******************************!*\
!*** ./src/modules/Utils.ts ***!
\******************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const ReactDOM = __webpack_require__(/*! react-dom */ "./src/alias/react-dom.ts");
const PluginUtilities_1 = __webpack_require__(/*! ./PluginUtilities */ "./src/modules/PluginUtilities.ts");
exports.default = new class Utils {
constructor() { }
ReactToHTMLElement(ReactElement) {
const element = document.createElement("div");
ReactDOM.render(ReactElement, element);
return element;
}
get PluginUtils() { return PluginUtilities_1.default; }
getNestedProps(obj, path) {
let segments = path.split(".");
for (let seg of segments) {
obj = obj && (seg in obj) ? obj[seg] : undefined;
}
return obj;
}
DecimalColorToHex(color) {
return "#" + color.toString(16).toUpperCase();
}
HexColorToDecimal(color) {
color = color.replace(/[#;]/g, "");
let res = parseInt(color, 16);
if (isNaN(res))
throw new Error(`Invalid color: ${color}`);
return res;
}
removeDa(className) {
if (!className)
return className;
return className.split(" ").filter(e => !e.startsWith("da-")).join(" ");
}
FindReact(dom, traverseUp = 0) {
// taken from https://stackoverflow.com/questions/29321742/react-getting-a-component-from-a-dom-element-for-debugging#39165137
const key = Object.keys(dom).find(key => key.startsWith("__reactInternalInstance$"));
const domFiber = dom[key];
if (domFiber == null)
return null;
// react <16
if (domFiber._currentElement) {
let compFiber = domFiber._currentElement._owner;
for (let i = 0; i < traverseUp; i++) {
compFiber = compFiber._currentElement._owner;
}
return compFiber._instance;
}
// react 16+
const GetCompFiber = fiber => {
//return fiber._debugOwner; // this also works, but is __DEV__ only
let parentFiber = fiber.return;
while (typeof parentFiber.type == "string") {
parentFiber = parentFiber.return;
}
return parentFiber;
};
let compFiber = GetCompFiber(domFiber);
for (let i = 0; i < traverseUp; i++) {
compFiber = GetCompFiber(compFiber);
}
return compFiber.stateNode;
}
hasClass(classNames, className) {
if (!classNames || !className)
return false;
const classnames = classNames.split(" ");
for (let classname of this.removeDa(className).split(" ")) {
if (!classnames.includes(classname))
return false;
}
return true;
}
formatJSObject(obj) {
if (["string", "number", "boolean", "bigint", "undefined"].includes(typeof obj))
return JSON.stringify(obj);
if (obj === null)
return "null";
if (typeof obj === "function")
return String(obj);
if (typeof obj === "symbol")
return String(obj);
if (Array.isArray(obj)) {
if (!obj.length)
return "[]";
return `[\n ${obj.map(e => this.formatJSObject(e)).join(",\n ")}\n]`;
}
else {
const keys = Object.keys(obj);
if (keys.length === 0)
return "{}";
return `{\n ${keys.map(key => {
let original = key;
if (typeof key === "symbol")
key = "[" + String(key) + "]";
else {
if (typeof key === "number")
key = String(key);
else {
console.log(key);
if (isNaN(parseInt(key[0]))) {
key = this.formatJSObject(key);
}
else if (/[^\w\d_$]/g.test(key)) {
key = this.formatJSObject(key);
}
}
}
return `${key}: ${this.formatJSObject(obj[original])}`;
})}\n}`;
}
}
};
/***/ }),
/***/ "./src/modules/WebpackLoader.ts":
/*!**************************************!*\
!*** ./src/modules/WebpackLoader.ts ***!
\**************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.WebpackLoaderError = void 0;
const BDModules = window.BDModules;
exports.default = new class WebpackLoader {
constructor() { }
get(id) {
return BDModules.get(id);
}
find(filter) {
let result = BDModules.get(filter)[0];
if (!result) {
console.warn(filter, "couldn't find the module.");
}
return result;
}
findByUniqueProperties(props) {
return BDModules.get((mod) => {
if (mod.__esModule && ("default" in mod)) {
let doesMatch = true;
for (let prop of props) {
if (!Object.prototype.hasOwnProperty.call(mod.default, prop))
doesMatch = false;
}
if (doesMatch)
return true;
}
for (let prop of props) {
if (!Object.prototype.hasOwnProperty.call(mod, prop))
return false;
}
return true;
})[0];
}
filter(filter) {
return BDModules.get(filter);
}
filterByUniqueProperties(props) {
return BDModules.get((mod) => {
if (mod.__esModule && ("default" in mod)) {
let doesMatch = true;
for (let prop of props) {
if (!Object.prototype.hasOwnProperty.call(mod.default, prop))
doesMatch = false;
}
if (doesMatch)
return true;
}
for (let prop of props) {
if (!Object.prototype.hasOwnProperty.call(mod, prop))
return false;
}
return true;
});
}
};
class WebpackLoaderError extends Error {
constructor(message = "") {
message += "\n\tThis error is related to Lightcord not being able to find a WebpackModule. \n\tPlease show this error and a few lines of logs above this error. \n\tOpen an issue on https://github.com/Lightcord/Lightcord or in their discord server.";
super(message);
this.name = "WebpackLoaderError";
}
}
exports.WebpackLoaderError = WebpackLoaderError;
/***/ }),
/***/ "./src/modules/cloneNullProto.ts":
/*!***************************************!*\
!*** ./src/modules/cloneNullProto.ts ***!
\***************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
/**
* Recreate the given object without the __proto__. Useful for better formatting when output in console.
* @param obj The object to recreate
*/
function cloneNullProto(obj) {
let o = Object.create(null);
Object.keys(obj).forEach(k => {
o[k] = obj[k];
});
return o;
}
exports.default = cloneNullProto;
/***/ }),
/***/ "./src/modules/excludeProperties.ts":
/*!******************************************!*\
!*** ./src/modules/excludeProperties.ts ***!
\******************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
function excludeProperties(obj, props) {
let newObj = {};
Object.keys(obj).forEach((k) => {
if (props.includes(k))
return;
newObj[k] = obj[k];
});
return newObj;
}
exports.default = excludeProperties;
/***/ }),
/***/ "./src/modules/noop.ts":
/*!*****************************!*\
!*** ./src/modules/noop.ts ***!
\*****************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
function NOOP() { }
exports.default = NOOP;
/***/ }),
/***/ "./src/modules/patchers.ts":
/*!*********************************!*\
!*** ./src/modules/patchers.ts ***!
\*********************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.patch = void 0;
const Utils_1 = __webpack_require__(/*! ./Utils */ "./src/modules/Utils.ts");
const Notices_1 = __webpack_require__(/*! ../components/private/Notices */ "./src/components/private/Notices.tsx");
function patch() {
/** START NOTICE */
getModule(e => e.default && e.default.displayName === "ConnectedAppView")
.then(async (mod) => {
const appClasses = await getModule(e => e.hasNotice);
const buildRender = original => {
return function render() {
const returnValue = original.call(this, ...arguments);
const newchildren = [];
let children = returnValue.props.children[1].props.children;
if (!Array.isArray(children))
children = [children];
newchildren.push(children[0]);
newchildren.push(React.createElement(Notices_1.default, { container: this }));
newchildren.push(children[1]);
returnValue.props.children[1].props.children = newchildren;
returnValue.props.children[1].props.children[2].props.children[0].props.render = buildRenderChannelSidebar(returnValue.props.children[1].props.children[2].props.children[0].props.render);
return returnValue;
};
};
const buildRenderChannelSidebar = original => {
return function renderChannelSidebar() {
const returnValue = original.call(this, ...arguments);
const hasNotice = Notices_1.notices.length > 0;
if (!hasNotice)
return returnValue;
if (!Utils_1.default.hasClass(returnValue.props.className, appClasses.hasNotice)) {
returnValue.props.className += " " + Utils_1.default.removeDa(appClasses.hasNotice);
}
return returnValue;
};
};
mod.default.prototype.render = buildRender(mod.default.prototype.render);
(async function () {
const base = document.querySelector("." + Utils_1.default.removeDa(appClasses.base));
if (!base)
throw new Error(`Could not find base here`);
const elem = Utils_1.default.FindReact(base);
elem.render = buildRender(elem.render);
elem.forceUpdate();
})();
});
/** END NOTICE */
/** START IN-APP NOTIFICATIONS */
//getModule(e => true)
/** END IN-APP NOTIFICATIONS */
}
exports.patch = patch;
function getModule(filter) {
return new Promise((resolve) => {
window.Lightcord.Api.ensureExported(filter)
.then(resolve)
.catch(err => {
console.error("[LIGHTCORD]", err, filter);
});
});
}
/***/ }),
/***/ "./src/modules/uuid.ts":
/*!*****************************!*\
!*** ./src/modules/uuid.ts ***!
\*****************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const uuidv1 = __webpack_require__(/*! uuid/v1 */ "uuid/v1");
const uuidv4 = __webpack_require__(/*! uuid/v4 */ "uuid/v4");
let uuid = Object.assign(function () {
return uuidv4();
}, { v1: () => uuidv1(), v4: () => uuidv4() });
exports.default = uuid;
/***/ }),
/***/ "events":
/*!*************************!*\
!*** external "events" ***!
\*************************/
/*! no static exports found */
/***/ (function(module, exports) {
module.exports = require("events");
/***/ }),
/***/ "uuid/v1":
/*!**************************!*\
!*** external "uuid/v1" ***!
\**************************/
/*! no static exports found */
/***/ (function(module, exports) {
module.exports = require("uuid/v1");
/***/ }),
/***/ "uuid/v4":
/*!**************************!*\
!*** external "uuid/v4" ***!
\**************************/
/*! no static exports found */
/***/ (function(module, exports) {
module.exports = require("uuid/v4");
/***/ })
/******/ });
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://LightcordApi/webpack/bootstrap","webpack://LightcordApi/./src/alias/react-dom.ts","webpack://LightcordApi/./src/components/components.ts","webpack://LightcordApi/./src/components/general/AlertBox.tsx","webpack://LightcordApi/./src/components/general/CodeBlock.tsx","webpack://LightcordApi/./src/components/general/SettingSubTitle.tsx","webpack://LightcordApi/./src/components/general/SettingsTitle.tsx","webpack://LightcordApi/./src/components/general/Tabs.tsx","webpack://LightcordApi/./src/components/general/Title.tsx","webpack://LightcordApi/./src/components/general/Tooltip.ts","webpack://LightcordApi/./src/components/inputs/Button.tsx","webpack://LightcordApi/./src/components/inputs/ColorPicker.tsx","webpack://LightcordApi/./src/components/inputs/Dropdown.tsx","webpack://LightcordApi/./src/components/inputs/RadioGroup.tsx","webpack://LightcordApi/./src/components/inputs/Switch.tsx","webpack://LightcordApi/./src/components/inputs/TextArea.tsx","webpack://LightcordApi/./src/components/inputs/TextInput.tsx","webpack://LightcordApi/./src/components/private/Notice.tsx","webpack://LightcordApi/./src/components/private/Notices.tsx","webpack://LightcordApi/./src/index.ts","webpack://LightcordApi/./src/modules/DiscordTools.ts","webpack://LightcordApi/./src/modules/PluginUtilities.ts","webpack://LightcordApi/./src/modules/Unfreeze.ts","webpack://LightcordApi/./src/modules/Utils.ts","webpack://LightcordApi/./src/modules/WebpackLoader.ts","webpack://LightcordApi/./src/modules/cloneNullProto.ts","webpack://LightcordApi/./src/modules/excludeProperties.ts","webpack://LightcordApi/./src/modules/noop.ts","webpack://LightcordApi/./src/modules/patchers.ts","webpack://LightcordApi/./src/modules/uuid.ts","webpack://LightcordApi/external \"events\"","webpack://LightcordApi/external \"uuid/v1\"","webpack://LightcordApi/external \"uuid/v4\""],"names":[],"mappings":"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","file":"main.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/index.ts\");\n","// bait typescript into thinking this is not reactDOM so no circular dependency.\r\nexport = window[\"Reac\"+\"tDOM\"] as typeof import(\"react-dom\")","import DiscordButton from \"./inputs/Button\"\r\nimport Switch from \"./inputs/Switch\"\r\nimport RadioGroup from \"./inputs/RadioGroup\"\r\nimport TextArea from \"./inputs/TextArea\"\r\nimport TextInput from \"./inputs/TextInput\"\r\nimport Dropdown from \"./inputs/Dropdown\"\r\nimport Title from \"./general/Title\"\r\nimport SettingsTitle from \"./general/SettingsTitle\"\r\nimport Tabs, { Tab } from \"./general/Tabs\"\r\nimport SettingSubTitle from \"./general/SettingSubTitle\"\r\nimport CodeBlock from \"./general/CodeBlock\"\r\nimport cloneNullProto from \"../modules/cloneNullProto\"\r\nimport Tooltip from \"./general/Tooltip\"\r\nimport ColorPicker from \"./inputs/ColorPicker\"\r\nimport AlertBox from \"./general/AlertBox\"\r\n\r\nexport default cloneNullProto({\r\n    inputs: cloneNullProto({\r\n        Button: DiscordButton,\r\n        Switch: Switch,\r\n        Choices: RadioGroup,\r\n        RadioGroup: RadioGroup,\r\n        TextArea: TextArea,\r\n        TextInput: TextInput,\r\n        Dropdown: Dropdown,\r\n        ColorPicker: ColorPicker\r\n    }),\r\n    general: cloneNullProto({\r\n        Title: Title,\r\n        SettingsTitle: SettingsTitle,\r\n        SettingSubTitle: SettingSubTitle,\r\n        Tabs: Tabs,\r\n        CodeBlock: CodeBlock,\r\n        Tooltip: Tooltip,\r\n        AlertBox: AlertBox\r\n    })\r\n})","import WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport { ReactNode } from \"react\"\r\n\r\ntype AlertBoxProps = {\r\n    type: \"warn\"|\"info\"|\"danger\"|\"error\"|\"success\",\r\n    children: ReactNode|string\r\n}\r\n\r\nlet AlertBoxModules\r\nexport default class AlertBox extends React.Component<AlertBoxProps> {\r\n    static defaultProps:AlertBoxProps = {\r\n        type: \"info\",\r\n        children: null\r\n    }\r\n\r\n    get modules(){\r\n        return AlertBoxModules || (AlertBoxModules = [\r\n            WebpackLoader.find(e => e.default && e.default.displayName === \"Markdown\" && e.default.defaultProps.parser).default\r\n        ])\r\n    }\r\n\r\n    render(){\r\n        const [\r\n            Markdown\r\n        ] = this.modules\r\n\r\n        let wrap\r\n        let children\r\n        if(typeof this.props.children === \"string\"){\r\n            wrap = Markdown.prototype.render.call({\r\n                props: Object.assign({\r\n                    className: \"\",\r\n                    children: this.props.children\r\n                }, Markdown.defaultProps)\r\n            })\r\n            children = wrap.props.children\r\n        }else{\r\n            wrap = Markdown.prototype.render.call({\r\n                props: Object.assign({\r\n                    className: \"\",\r\n                    children: \"\"\r\n                }, Markdown.defaultProps)\r\n            })\r\n            children = this.props.children\r\n        }\r\n        wrap.props.children = <div className={\"lc-alert-box lc-alert-box-\"+this.props.type}>\r\n            <blockquote className=\"lc-blockquote\">\r\n                {children}\r\n            </blockquote>\r\n        </div>\r\n        return wrap\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([\r\n                {\r\n                    children: \"***Discord's*** **Markdown** _is_ [supported](https://google.com) or you can just insert your own react childs.\"\r\n                }\r\n            ], [\r\n                {\r\n                    type: \"info\"\r\n                },\r\n                {\r\n                    type: \"success\"\r\n                },\r\n                {\r\n                    type: \"warn\"\r\n                },\r\n                {\r\n                    type: \"error\"\r\n                }\r\n            ])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n\r\n    static help = {\r\n        info: \"You can insert markdown (as string) or normal react childs\",\r\n        warn: \"All string will be interpreted as markdown. If you want raw string, pass an array with the string inside.\"\r\n    }\r\n}\r\nlet AllPreviews","import WebpackLoader from \"../../modules/WebpackLoader\"\r\n\r\ntype CodeBlockProps = {\r\n    language?: string,\r\n    content: string\r\n}\r\n\r\nlet CodeBlockModules\r\nexport default class CodeBlock extends React.Component<CodeBlockProps> {\r\n    static defaultProps:CodeBlockProps = {\r\n        language: \"plaintext\",\r\n        content: \"\"\r\n    }\r\n    \r\n    get modules(){\r\n        return CodeBlockModules || (CodeBlockModules = [\r\n            WebpackLoader.find(e => e.markup),\r\n            WebpackLoader.find(e => e.messageContent),\r\n            WebpackLoader.find(e => e.scrollbarGhostHairline),\r\n            WebpackLoader.find(e => e.highlight),\r\n            WebpackLoader.find(e => e.marginBottom8)\r\n        ])\r\n    }\r\n\r\n    render(){\r\n        let [\r\n            messageModule1,\r\n            messageModule2,\r\n            scrollbarModule1,\r\n            hightlightJS,\r\n            marginModule1\r\n        ] = this.modules\r\n\r\n        const code = this.props.language === \"plaintext\" ? <code className={`${scrollbarModule1.scrollbarGhostHairline} hljs`}>\r\n            {this.props.content}\r\n        </code> : <code className={`${scrollbarModule1.scrollbarGhostHairline} hljs`} \r\n            dangerouslySetInnerHTML={{__html: hightlightJS.highlight(this.props.language, this.props.content).value}} />\r\n        return (<div className={`${messageModule1.markup} ${messageModule2.messageContent}`}>\r\n            <pre>\r\n                {code}\r\n            </pre>\r\n            <div className={marginModule1.marginBottom8}></div>\r\n        </div>)\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([\r\n                {\r\n                    content: \"console.log(\\\"Exemple code\\\")\"\r\n                }\r\n            ])\r\n            AllPreviews.push([\r\n                {\r\n                    language: \"js\"\r\n                },\r\n                {\r\n                    language: \"plaintext\"\r\n                },\r\n                ...CodeBlock.prototype.modules[3].listLanguages().filter(e => e !== \"js\").map(e => ({language: e}))\r\n            ])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n}\r\nlet AllPreviews","import WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport { ReactNode } from \"react\"\r\nimport Utils from \"../../modules/Utils\"\r\n\r\ntype SettingSubTitleProps = {\r\n    children: ReactNode\r\n    className?: string\r\n}\r\n\r\nlet TitleModules\r\nexport default class SettingSubTitle extends React.Component<SettingSubTitleProps> {\r\n    static defaultProps:SettingSubTitleProps = {\r\n        children: [],\r\n        className: \"\"\r\n    }\r\n\r\n    get modules(){\r\n        return TitleModules || (TitleModules = [\r\n            WebpackLoader.find(e => typeof e.marginTop60 === \"string\"),\r\n            WebpackLoader.findByUniqueProperties([\"h5\"]),\r\n            window.Lightcord.Api.WebpackLoader.findByUniqueProperties([\"size14\"]),\r\n            window.Lightcord.Api.WebpackLoader.findByUniqueProperties([\"colorStandard\"])\r\n        ])\r\n    }\r\n\r\n    render(){\r\n        let [\r\n            marginModule,\r\n            titleModule,\r\n            sizeModule,\r\n            colorModule\r\n        ] = this.modules\r\n\r\n        let props = this.props\r\n\r\n        let className = `${colorModule.colorStandard} ${sizeModule.size14} ${titleModule.h5} ${marginModule.marginBottom4}`\r\n        if(props.className)className =+ \" \"+props.className\r\n        \r\n        return React.createElement(\"h5\", {className}, props.children)\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([\r\n                {\r\n                    children: \"Exemple title\"\r\n                }\r\n            ])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n}\r\nlet AllPreviews","import WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport Title from \"./Title\"\r\nimport { ReactNode } from \"react\"\r\n\r\ntype SettingsTitleProps = {\r\n    children: ReactNode\r\n    className?: string\r\n}\r\n\r\nlet TitleModules\r\nexport default class SettingsTitle extends React.Component<SettingsTitleProps> {\r\n    constructor(props: SettingsTitleProps){\r\n        super(props)\r\n    }\r\n\r\n    get modules(){\r\n        return TitleModules || (TitleModules = [\r\n            WebpackLoader.find(e => typeof e.marginTop60 === \"string\")\r\n        ])\r\n    }\r\n\r\n    render(){\r\n        let [\r\n            marginModule\r\n        ] = this.modules\r\n\r\n        let props = this.props\r\n\r\n        let className = `${marginModule.marginTop60} ${marginModule.marginBottom20}`\r\n        if(props.className)className =+ \" \"+props.className\r\n        \r\n        return React.createElement(Title, {className}, props.children)\r\n    }\r\n\r\n    static defaultProps:SettingsTitleProps = {\r\n        children: [\"\"],\r\n        className: \"\"\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([\r\n                {\r\n                    children: \"Exemple title\"\r\n                }\r\n            ])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n}\r\nlet AllPreviews","import { ReactNode, CSSProperties } from \"react\"\r\nimport NOOP from \"../../modules/noop\"\r\nimport Title from \"./Title\"\r\n\r\ntype TabsProps = {\r\n    children?: ReactNode,\r\n    tabs: {label: string, id: string}[],\r\n    active?: string\r\n    onChange?: (tab: string) => void,\r\n    style?: CSSProperties\r\n}\r\n\r\nexport default class Tabs extends React.Component<TabsProps, {\r\n    active: string\r\n}> {\r\n    static defaultProps:TabsProps = {\r\n        children: null,\r\n        tabs: [{label: \"No tabs was passed to <Tabs>.\", id: \"none\"}],\r\n        active: null,\r\n        onChange: NOOP,\r\n        style: {}\r\n    }\r\n    \r\n    constructor(props:TabsProps){\r\n        super(props)\r\n        this.state = {\r\n            active: this.props.active || null\r\n        }\r\n    }\r\n\r\n    tabsElements:Tab[] = []\r\n    \r\n    get tabs():Tabs[\"props\"][\"tabs\"]{\r\n        return this.props.tabs || []\r\n    }\r\n\r\n    changeTab(tab:string){\r\n        if(tab === this.state.active)return\r\n        if(this.props.onChange)this.props.onChange(tab)\r\n        this.setState({\r\n            active: tab\r\n        })\r\n        this.tabsElements.forEach(e => e.setActive(tab === e.props.id))\r\n    }\r\n\r\n    render(){\r\n        return (<div className=\"lc-tabWrapper\" style={this.props.style}>\r\n            <div className=\"lc-tabnav\" style={{flex: \"0 1 auto\"}}>\r\n                {this.tabs.map(tab => {\r\n                    return React.createElement(Tab, {TabContainer: this, title: tab.label, id: tab.id, key: btoa(tab.label+\":\"+tab.id)})\r\n                })}\r\n            </div>\r\n            <div className=\"lc-tab\">\r\n                {this.props.children}\r\n            </div>\r\n        </div>)\r\n    }   \r\n\r\n    isActive(tab){\r\n        return this.state.active === tab\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([\r\n                {\r\n                    children: (<div style={{marginTop: \"20px\", marginBottom: \"20px\"}}>\r\n                        <div style={{\r\n                            backgroundColor: \"var(--background-primary)\", \r\n                            padding: \"30px 30px\", \r\n                            borderRadius: \"8px\"\r\n                        }} className=\"lc-tab-box-shadow\">\r\n                            <Title>Preview tabs</Title>\r\n                        </div>\r\n                    </div>)\r\n                }\r\n            ], [\r\n                {\r\n                    tabs: [\r\n                        {\r\n                            label: \"Active tab\",\r\n                            id: \"1\"\r\n                        },\r\n                        {\r\n                            label: \"Unactive tab\",\r\n                            id: \"2\"\r\n                        }\r\n                    ]\r\n                }\r\n            ], [\r\n                {\r\n                    active: \"1\"\r\n                }\r\n            ], [\r\n                {\r\n                    onChange: (tabId) => {}\r\n                }\r\n            ])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n}\r\nlet AllPreviews\r\n\r\nexport class Tab extends React.Component<{\r\n    TabContainer: Tabs, \r\n    title: string, \r\n    id: string\r\n}, {\r\n    active: boolean\r\n}> {\r\n    constructor(props){\r\n        super(props)\r\n\r\n        this.state = {\r\n            active: props.TabContainer.isActive(props.id)\r\n        }\r\n\r\n        this.props.TabContainer.tabsElements.push(this)\r\n    }\r\n\r\n    setActive(isActive:boolean){\r\n        this.setState({\r\n            active: !!isActive\r\n        })\r\n    }\r\n\r\n    render(){\r\n        let className = `lc-navItem`\r\n        if(this.state.active){\r\n            className += ` lc-navItemActive`\r\n        }else{\r\n            className += ` lc-navItemInactive`\r\n        }\r\n        return (<div className={className} onClick={()=>{\r\n            this.props.TabContainer.changeTab(this.props.id)\r\n        }}>\r\n            {this.props.title}\r\n        </div>)\r\n    }\r\n}","import WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport { ReactNode } from \"react\"\r\n\r\ntype TitleProps = {\r\n    children?: ReactNode,\r\n    className?: string\r\n}\r\n\r\nlet TitleModules\r\nexport default class Title extends React.Component<TitleProps> {\r\n    constructor(props: TitleProps){\r\n        super(props)\r\n    }\r\n\r\n    get modules(){\r\n        return TitleModules || (TitleModules = [\r\n            WebpackLoader.find(e => typeof e.colorStandard === \"string\"),\r\n            WebpackLoader.find(e => typeof e.size32 === \"string\"),\r\n            WebpackLoader.find(e => typeof e.h2 === \"string\")\r\n        ])\r\n    }\r\n\r\n    render(){\r\n        let [\r\n            colorModule,\r\n            sizeModule,\r\n            titleModule\r\n        ] = this.modules\r\n\r\n        let props = this.props\r\n\r\n        let className = `${colorModule.colorStandard} ${sizeModule.size14} ${titleModule.h2} ${titleModule.defaultColor} ${titleModule.defaultMarginh2}`\r\n        if(props.className)className += \" \"+props.className\r\n\r\n        return React.createElement(\"h2\", {className}, props.children)\r\n    }\r\n    \r\n    static defaultProps:TitleProps = {\r\n        children: null,\r\n        className: null\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([\r\n                {\r\n                    children: \"Exemple title\"\r\n                }\r\n            ])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n}\r\nlet AllPreviews","import WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport { ReactNode } from \"react\"\r\nimport excludeProperties from \"../../modules/excludeProperties\"\r\n\r\ntype TooltipData = {\r\n    onClick():void\r\n    onMouseEnter():void\r\n    onMouseLeave():void\r\n    onContextMenu():void\r\n    \"aria-label\": string\r\n}\r\ntype TooltipProps = {\r\n    children:ReactNode,\r\n    text: string,\r\n    position?: TooltipPosition,\r\n    color?: TooltipColor\r\n}\r\n\r\nlet TooltipModules\r\nexport default class Tooltip extends React.Component<TooltipProps> {\r\n    constructor(props: TooltipProps){\r\n        super(props)\r\n    }\r\n\r\n    get modules(){\r\n        return TooltipModules || (TooltipModules = [\r\n            WebpackLoader.find(e => e.default && e.default.displayName === \"Tooltip\")\r\n        ])\r\n    }\r\n\r\n    render(){\r\n        let [\r\n            Tooltip\r\n        ] = this.modules\r\n\r\n        let props = excludeProperties(this.props, [\"children\"])\r\n\r\n        return React.createElement(Tooltip.default, props, (data:TooltipData) => {\r\n            return React.createElement(\"div\", {\r\n                ...data,\r\n                style: {\r\n                    width: \"fit-content\",\r\n                    height: \"fit-content\"\r\n                }\r\n            }, this.props.children)\r\n        })\r\n    }\r\n    \r\n    static defaultProps:TooltipProps = {\r\n        children: null,\r\n        text: \"No text was passed to Tooltip\",\r\n        position: \"top\",\r\n        color: \"brand\"\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([\r\n                {\r\n                    children: React.createElement(window.Lightcord.Api.Components.inputs.Button, {\r\n                        color: \"green\",\r\n                        look: \"ghost\",\r\n                        size: \"small\",\r\n                        hoverColor: \"yellow\",\r\n                        onClick: () => { },\r\n                        wrapper: false\r\n                    }, \"Hover this button to see the tooltip\")\r\n                }\r\n            ])\r\n            AllPreviews.push([\r\n                {\r\n                    text: \"Example Tooltip Text\"\r\n                }\r\n            ])\r\n            let colors = []\r\n            Tooltip.Colors.forEach(color => {\r\n                colors.push({\r\n                    color: color\r\n                })\r\n            })\r\n            AllPreviews.push(colors)\r\n            let positions = []\r\n            Tooltip.Positions.forEach(p => {\r\n                positions.push({\r\n                    position: p\r\n                })\r\n            })\r\n            AllPreviews.push(positions)\r\n            return AllPreviews\r\n        })()\r\n    }\r\n\r\n    static Positions:TooltipPosition[] = [\"top\", \"left\", \"right\", \"bottom\"]\r\n    static Colors:TooltipColor[] = [\"black\", \"grey\", \"brand\", \"green\", \"yellow\", \"red\"]\r\n}\r\nlet AllPreviews\r\n\r\nexport type TooltipPosition = \"top\" | \"left\" | \"right\" | \"bottom\"\r\nexport type TooltipColor = \"black\" | \"grey\" | \"brand\" | \"green\" | \"yellow\" | \"red\"","import WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport { MouseEventHandler, ReactNode } from \"react\"\r\n\r\nlet ButtonModules\r\n\r\ntype ButtonProps = {\r\n    children?: ReactNode,\r\n    onClick?: MouseEventHandler,\r\n    color?: ButtonColor,\r\n    wrapper?: boolean,\r\n    look?: ButtonLook,\r\n    size?: ButtonSize,\r\n    hoverColor?: ButtonHovers,\r\n    disabled?: boolean\r\n}\r\nexport default class Button extends React.Component<ButtonProps, {hover: boolean}> {\r\n    constructor(props:ButtonProps){\r\n        super(props)\r\n\r\n        this.state = {\r\n            hover: false\r\n        }\r\n    }\r\n\r\n    static Colors:ButtonColor[] = [\"brand\", \"grey\", \"red\", \"green\", \"yellow\", \"primary\", \"link\", \"white\", \"black\", \"transparent\"]\r\n    static Looks:ButtonLook[] = [\"filled\", \"inverted\", \"outlined\", \"ghost\", \"link\", \"blank\"]\r\n    static Sizes:ButtonSize[] = [\"small\", \"medium\", \"large\", \"xlarge\", \"min\", \"max\", \"icon\", \"none\"]\r\n    static HoverColors: ButtonHovers[] = [\"default\", ...Button.Colors]\r\n\r\n    get modules(){ // caching modules\r\n        return ButtonModules || (ButtonModules = [\r\n            WebpackLoader.findByUniqueProperties([\"_horizontal\"]),\r\n            WebpackLoader.findByUniqueProperties([\"colorTransparent\"]),\r\n            WebpackLoader.findByUniqueProperties([\"buttonWrapper\"]),\r\n            WebpackLoader.findByUniqueProperties([\"ButtonColors\"]),\r\n        ])\r\n    }\r\n\r\n    render(){\r\n        let [\r\n            flexModule,\r\n            euhModule1,\r\n            buttonModule,\r\n            colorsModule,\r\n        ] = this.modules\r\n\r\n        let props:ButtonProps = {}\r\n        if(this.props){\r\n            if(\"color\" in this.props){\r\n                props.color = this.props.color\r\n            }\r\n            if(\"children\" in this.props){\r\n                props.children = this.props.children\r\n            }\r\n            if(\"onClick\" in this.props){\r\n                props.onClick = this.props.onClick\r\n            }\r\n            if(\"wrapper\" in this.props){\r\n                props.wrapper = !!this.props.wrapper\r\n            }\r\n            if(\"look\" in this.props){\r\n                props.look = this.props.look\r\n            }\r\n            if(\"size\" in this.props){\r\n                props.size = this.props.size\r\n            }\r\n            if(\"hoverColor\" in this.props){\r\n                props.hoverColor = this.props.hoverColor\r\n            }\r\n            if(\"disabled\" in this.props){\r\n                props.disabled = this.props.disabled\r\n            }else{\r\n                props.disabled = false\r\n            }\r\n        }\r\n\r\n        if(props.color){\r\n            props.color = props.color.toLowerCase() as ButtonColor\r\n            if(!Button.Colors.includes(props.color)){\r\n                props.color = Button.Colors[0]\r\n            }\r\n        }else{\r\n            props.color = Button.Colors[0]\r\n        }\r\n\r\n        if(props.look){\r\n            props.look = props.look.toLowerCase() as ButtonLook\r\n            if(!Button.Looks.includes(props.look)){\r\n                props.look = Button.Looks[0]\r\n            }\r\n        }else{\r\n            props.look = Button.Looks[0]\r\n        }\r\n\r\n        if(props.size){\r\n            props.size = props.size.toLowerCase() as ButtonSize\r\n            if(!Button.Sizes.includes(props.size)){\r\n                props.size = Button.Sizes[0]\r\n            }\r\n        }else{\r\n            props.size = Button.Sizes[0]\r\n        }\r\n\r\n        if(props.hoverColor){\r\n            props.hoverColor = props.hoverColor.toLowerCase() as ButtonHovers\r\n            if(!Button.HoverColors.includes(props.hoverColor)){\r\n                props.hoverColor = Button.HoverColors[0]\r\n            }\r\n        }else{\r\n            props.hoverColor = Button.HoverColors[0]\r\n        }\r\n\r\n        let buttonSize = props.size ? colorsModule.ButtonSizes[props.size.toUpperCase()] || \"\" : \"\"\r\n        if(buttonSize)buttonSize = \" \" + buttonSize\r\n\r\n        let hoverColor = props.hoverColor ? colorsModule.ButtonHovers[props.hoverColor.toUpperCase()] || \"\" : \"\"\r\n        if(hoverColor)hoverColor = \" \" + hoverColor\r\n\r\n        props.onClick = typeof props.onClick === \"function\" ? props.onClick : () => {}\r\n        if(typeof props.wrapper !== \"boolean\")props.wrapper = true\r\n\r\n        let hover = this.state.hover ? euhModule1.hasHover : \"\"\r\n        if(hover)hover = \" \" + hover\r\n\r\n        let button = <button type=\"button\" \r\n            className={`${flexModule.flexChild} ${euhModule1.button} ${colorsModule.ButtonLooks[props.look.toUpperCase()]} ${colorsModule.ButtonColors[props.color.toUpperCase()]}${buttonSize}${hoverColor}${hover} ${euhModule1.grow}`} \r\n            style={{flex: \"0 1 auto\"}} onClick={this.props.onClick} onMouseEnter={(ev) => {\r\n                if(!hoverColor)return\r\n                this.setState({hover: true})\r\n            }} onMouseLeave={(ev) => {\r\n                if(!hoverColor)return\r\n                this.setState({hover: false})\r\n            }} disabled={props.disabled}>\r\n            <div className={euhModule1.contents}>{props.children}</div>\r\n        </button>\r\n\r\n        if(props.wrapper){\r\n            return <div className={buttonModule.buttonWrapper}>\r\n                {button}\r\n            </div>\r\n        }\r\n        return button\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            let colors = []\r\n            for(let color of Button.Colors){\r\n                colors.push({\r\n                    color: color\r\n                })\r\n            }\r\n            AllPreviews.push(colors)\r\n            let looks = []\r\n            for(let look of Button.Looks){\r\n                looks.push({\r\n                    look: look\r\n                })\r\n            }\r\n            AllPreviews.push(looks)\r\n            let sizes = []\r\n            for(let size of Button.Sizes){\r\n                sizes.push({\r\n                    size: size\r\n                })\r\n            }\r\n            AllPreviews.push(sizes)\r\n            let hovers = []\r\n            for(let hover of Button.HoverColors){\r\n                hovers.push({\r\n                    hoverColor: hover\r\n                })\r\n            }\r\n            AllPreviews.push(hovers)\r\n            AllPreviews.push([{children: \"Test Button\"}])\r\n            AllPreviews.push([{onClick: () => {}}])\r\n            AllPreviews.push([{wrapper: false}])\r\n            AllPreviews.push([{disabled: false}, {disabled: true}])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n}\r\nlet AllPreviews\r\n\r\n\r\nexport type ButtonColor = \"brand\" | \"grey\" | \"red\" | \"green\" | \"yellow\" | \"primary\" | \"link\" | \"white\" | \"black\" | \"transparent\"\r\nexport type ButtonLook = \"filled\" | \"inverted\" | \"outlined\" | \"ghost\" | \"link\" | \"blank\"\r\nexport type ButtonSize = \"none\" | \"small\" | \"medium\" | \"large\" | \"xlarge\" | \"min\" | \"max\" | \"icon\"\r\nexport type ButtonHovers = \"default\" | ButtonColor","import NOOP from \"../../modules/noop\"\r\nimport WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport Tooltip from \"../general/Tooltip\"\r\nimport Utils from \"../../modules/Utils\"\r\n\r\nconst Constants = {\r\n    defaultColor: 10070709,\r\n    baseColors: [\r\n        1752220, \r\n        3066993, \r\n        3447003, \r\n        10181046, \r\n        15277667, \r\n        15844367, \r\n        15105570, \r\n        15158332, \r\n        9807270, \r\n        6323595, \r\n        1146986, \r\n        2067276, \r\n        2123412, \r\n        7419530, \r\n        11342935, \r\n        12745742, \r\n        11027200, \r\n        10038562, \r\n        9936031, \r\n        5533306\r\n    ]\r\n}\r\n\r\ntype ColorPickerProps = {\r\n    defaultColor?: number,\r\n    customColor?: number,\r\n    baseColors?: number[],\r\n    value?: string,\r\n    disabled?: boolean,\r\n    onChange?: (color:number) => void\r\n}\r\n\r\nlet ColorPickerModules\r\nlet isFetching = null\r\n\r\n/**\r\n * This componennt needs to be loaded. As a result, you may experience 100-300ms loading the first time.\r\n * Render will return `null` before loaded.\r\n */\r\nexport default class ColorPicker extends React.PureComponent<ColorPickerProps, {value?:string,lastColor:any}> {\r\n    constructor(props:ColorPickerProps){\r\n        super(props)\r\n        this.state = {\r\n            value: props.value || null,\r\n            lastColor: this.props.value\r\n        }\r\n        this.onChange = this.onChange.bind(this)\r\n    }\r\n\r\n    /** Preload the component. */\r\n    static preload(){\r\n        if(ColorPicker.prototype.modules[0])return\r\n        if(isFetching)return\r\n        new ColorPicker({}).render()\r\n    }\r\n\r\n    onChange(val){\r\n        this.props.onChange(val)\r\n        this.setState({\r\n            value: val\r\n        })\r\n        this.forceUpdate()\r\n    }\r\n\r\n    static defaultProps:ColorPickerProps = {\r\n        defaultColor: Constants.defaultColor,\r\n        customColor: null,\r\n        baseColors: Constants.baseColors,\r\n        value: null,\r\n        disabled: false,\r\n        onChange: NOOP\r\n    }\r\n\r\n    get modules(){\r\n        return ColorPickerModules || (ColorPickerModules = [\r\n            WebpackLoader.find(e => e.default && e.default.displayName === \"ColorPicker\")\r\n        ])\r\n    }\r\n\r\n    renderColorPicker(){\r\n        let [\r\n            ColorPickerComponent\r\n        ] = this.modules\r\n\r\n        if(!ColorPickerComponent){\r\n            if(isFetching){ // support for multiple color picker\r\n                isFetching.then(() => this.forceUpdate())\r\n                return null\r\n            }\r\n            ColorPickerModules = null\r\n            let resolve\r\n            isFetching = new Promise(res => (resolve = res))\r\n            const GuildSettingsRoles = new (WebpackLoader.find(e => e.default && e.default.displayName && e.default.displayName.includes(\"GuildSettingsRoles\")).default)().render().type\r\n            const settings = GuildSettingsRoles.prototype.renderRoleSettings.call({\r\n                props: {\r\n                    guild: {\r\n                        roles: [],\r\n                        id: null,\r\n                        isOwner: () => false\r\n                    },\r\n                    currentUser: {\r\n                        id: null\r\n                    }\r\n                },\r\n                getSelectedRole(){\r\n                    return {\r\n                        id: null\r\n                    }\r\n                }\r\n            })\r\n            const GuildRoleSettings = settings.props.children.type\r\n            let children = GuildRoleSettings.prototype.renderColorPicker.call({\r\n                props: {\r\n                    role: {\r\n                        id: null,\r\n                        color: 0\r\n                    },\r\n                    locked: false,\r\n                    everyone: false\r\n                }\r\n            }).props.children\r\n            children.type(children.props).props.children.type._ctor().then(c => {\r\n                this.forceUpdate()\r\n                resolve()\r\n            })\r\n\r\n            return null\r\n        }\r\n        return <ColorPickerComponent.default colors={this.props.baseColors} defaultColor={this.props.defaultColor} value={this.state.value} \r\n            disabled={this.props.disabled} onChange={this.onChange} customColor={this.props.customColor}>\r\n        </ColorPickerComponent.default>\r\n    }\r\n\r\n    render(){\r\n        if(this.state.lastColor !== this.props.value){\r\n            this.state = {\r\n                value: this.props.value,\r\n                lastColor: this.props.value\r\n            }\r\n        }\r\n        return this.renderColorPicker()\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([\r\n                {\r\n                    disabled: false\r\n                },\r\n                {\r\n                    disabled: true\r\n                }\r\n            ], [\r\n                {\r\n                    value: Utils.HexColorToDecimal(\"#7289DA\")\r\n                }, {\r\n                    value: null\r\n                }\r\n            ], [\r\n                {\r\n                    onChange: (color) => {}\r\n                }\r\n            ])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n\r\n    static help = {\r\n        info: \"To convert hex colors to decimal, you can do `Lightcord.Api.Utils.HexColorToDecimal('#yourcolor')` and go back with `Lightcord.Api.Utils.DecimalColorToHex(7506394)`\",\r\n        warn: \"The component may not appear instantly. The component needs to be loaded, so you could experience 50-300ms loading time depending on your internet connection.\"\r\n    }\r\n}\r\nlet AllPreviews","import NOOP from \"../../modules/noop\"\r\nimport WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport { ReactNode, CSSProperties } from \"react\"\r\n\r\ntype DropdownProps = {\r\n    className?: string,\r\n    error?: string,\r\n    options?: {\r\n        value: string,\r\n        label: string\r\n    }[],\r\n    valueRenderer?: (data) => ReactNode,\r\n    optionRenderer?: (data) => ReactNode,\r\n    multiValueRenderer?: (data) => ReactNode\r\n    onChange?: (value: string) => void,\r\n    value?: string,\r\n    disabled?: boolean,\r\n    searchable?: boolean,\r\n    clearable?: boolean,\r\n    styleOverrides?: CSSProperties,\r\n    lightThemeColorOverrides?: themeOverride,\r\n    darkThemeColorOverrides?: themeOverride,\r\n    isMulti?: boolean\r\n}\r\n\r\ntype themeOverride = {\r\n    neutral0: string,\r\n    neutral5: string,\r\n    neutral10: string,\r\n    neutral20: string,\r\n    neutral30: string,\r\n    primary: string,\r\n    primary25: string,\r\n    primary50: string,\r\n    selectedOptionBackground: string,\r\n    text: string,\r\n    menuBackground: string,\r\n    menuBorder: string,\r\n    scrollBarThumb: string,\r\n    multiOptionBackground: string\r\n}\r\n\r\nlet DropdownModules\r\nexport default class Dropdown extends React.Component<DropdownProps, {value: string|null}> {\r\n    constructor(props:DropdownProps){\r\n        super(props)\r\n        this.onChange = this.onChange.bind(this)\r\n        this.state = {\r\n            value: props.value || null\r\n        }\r\n    }\r\n\r\n    static defaultProps:DropdownProps = {\r\n        className: null,\r\n        error: null,\r\n        options: [{\r\n            value: \"none\",\r\n            \"label\": \"No options - No options was passed to Dropdown. If you meant to put an empty dropdown, input an empty array.\"\r\n        }],\r\n        valueRenderer: null,\r\n        multiValueRenderer: null,\r\n        optionRenderer: null,\r\n        onChange: NOOP,\r\n        value: null,\r\n        disabled: false,\r\n        searchable: false,\r\n        clearable: false,\r\n        styleOverrides: null,\r\n        lightThemeColorOverrides: null,\r\n        darkThemeColorOverrides: null,\r\n        isMulti: false\r\n    }\r\n\r\n    onChange(value){\r\n        this.props.onChange(value)\r\n        this.setState({\r\n            value: value\r\n        })\r\n    }\r\n\r\n    get modules(){\r\n        return DropdownModules || (DropdownModules = [\r\n            WebpackLoader.find(e => e.default && e.default.displayName === \"SelectTempWrapper\").default\r\n        ])\r\n    }\r\n\r\n    render(){\r\n        let [\r\n            DropdownComponent\r\n        ] = this.modules\r\n\r\n        let props = this.props\r\n        let returnValue = <DropdownComponent {...props} onChange={this.onChange} value={this.state.value}/>\r\n        return returnValue\r\n    }\r\n\r\n    get value(){\r\n        return this.state.value\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([{\r\n                error: null\r\n            }, {\r\n                error: \"An error occured\"\r\n            }], [{\r\n                options: [\r\n                    {\r\n                        value: \"option1\",\r\n                        label: \"Option 1\"\r\n                    },\r\n                    {\r\n                        value: \"option2\",\r\n                        label: \"Option 2\"\r\n                    },\r\n                    {\r\n                        value: \"option3\",\r\n                        label: \"Option 3\"\r\n                    }\r\n                ]\r\n            }], [{\r\n                value: \"option1\"\r\n            }], [{\r\n                disabled: false\r\n            }, {\r\n                disabled: true\r\n            }], [{\r\n                searchable: true\r\n            }, {\r\n                searchable: false\r\n            }], [{\r\n                clearable: true\r\n            }, {\r\n                clearable: false\r\n            }], [{\r\n                isMulti: false\r\n            }, {\r\n                isMulti: true\r\n            }])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n}\r\nlet AllPreviews","import NOOP from \"../../modules/noop\"\r\nimport WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport Utils from \"../../modules/Utils\"\r\n\r\n\r\ntype RadioGroupProps = {\r\n    options?: {\r\n        color?: string,\r\n        name: string,\r\n        value: string,\r\n        desc?: string\r\n    }[],\r\n    onChange?: (value: string) => void,\r\n    value?: string,\r\n    disabled?: boolean,\r\n    size?: \"small\"|\"medium\",\r\n    itemType?: \"bar\"|\"panel\",\r\n    infoClassName?: string\r\n}\r\n\r\nlet RadioGroupModule\r\nexport default class RadioGroup extends React.Component<RadioGroupProps, {value?: string}> {\r\n    static defaultProps:RadioGroupProps = {\r\n        options: [{\r\n            value: \"none\",\r\n            name: \"No options\",\r\n            desc: \"No options was passed to Choices. If you meant to display no options at all, please pass an empty array.\",\r\n            color: \"#f04747\"\r\n        }],\r\n        value: null,\r\n        disabled: false,\r\n        size: \"medium\",\r\n        itemType: \"bar\",\r\n        infoClassName: null,\r\n        onChange: NOOP\r\n    }\r\n    constructor(props:RadioGroupProps){\r\n        super(props)\r\n        this.onChange = this.onChange.bind(this)\r\n        this.state = {\r\n            value: props.value\r\n        }\r\n    }\r\n\r\n    onChange(ev){\r\n        this.props.onChange(ev.value)\r\n        this.setState({\r\n            value: ev.value\r\n        })\r\n    }\r\n\r\n    get modules(){\r\n        return RadioGroupModule || (RadioGroupModule = [\r\n            WebpackLoader.find(e => e.default && e.default.displayName === \"RadioGroup\").default\r\n        ])\r\n    }\r\n\r\n    render(){\r\n        let [\r\n            RadioGroupComponent\r\n        ] = this.modules\r\n\r\n        let props = this.props\r\n        return <RadioGroupComponent options={props.options} onChange={this.onChange} value={this.state.value} disabled={props.disabled} \r\n            size={RadioGroupComponent.Sizes[props.size.toUpperCase()]} itemType={RadioGroupComponent.ItemTypes[props.itemType.toUpperCase()]} \r\n            infoClassName={props.infoClassName}/>\r\n    }\r\n\r\n    get value():string|null{\r\n        return this.state.value\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([{\r\n                options: [\r\n                    {\r\n                        value: \"option1\",\r\n                        name: \"Option 1\",\r\n                        desc: \"description 1\"\r\n                    },\r\n                    {\r\n                        value: \"option2\",\r\n                        name: \"Option 2\",\r\n                        desc: \"description 2\"\r\n                    },\r\n                    {\r\n                        value: \"option3\",\r\n                        name: \"Option 3\",\r\n                        desc: \"description 3\"\r\n                    }\r\n                ]\r\n            }], [{\r\n                value: \"option1\"\r\n            }], [{\r\n                disabled: false\r\n            }, {\r\n                disabled: true\r\n            }], [{\r\n                size: \"medium\"\r\n            }, {\r\n                size: \"small\"\r\n            }], [{\r\n                itemType: \"bar\"\r\n            }, {\r\n                itemType: \"panel\"\r\n            }])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n}\r\nlet AllPreviews","import WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport uuid from \"../../modules/uuid\"\r\nimport NOOP from \"../../modules/noop\"\r\nimport Utils from \"../../modules/Utils\"\r\n\r\ntype SwitchProps = {\r\n    id?: string,\r\n    onChange?: (checked: boolean) => void,\r\n    value?: boolean,\r\n    fill?: string,\r\n    theme?: \"default\"|\"clear\",\r\n    disabled?: boolean,\r\n    className?: string,\r\n    size?: \"default\"|\"mini\",\r\n    style?: React.CSSProperties\r\n}\r\n\r\nlet SwitchModules\r\nexport default class Switch extends React.Component<SwitchProps, {value: boolean}> {\r\n    constructor(props:SwitchProps){\r\n        super(props)\r\n\r\n        this.state = {\r\n            value: props.value || false\r\n        }\r\n        this.onChange = this.onChange.bind(this)\r\n    }\r\n\r\n    get modules(){\r\n        return SwitchModules || (SwitchModules = [\r\n            WebpackLoader.find(e => e.default && e.default.displayName === \"Switch\").default\r\n        ])\r\n    }\r\n\r\n    render(){\r\n        let [\r\n            SwitchComponent\r\n        ] = this.modules\r\n\r\n        let props = this.props\r\n        return (<SwitchComponent id={props.id} onChange={this.onChange} value={this.state.value || false} fill={props.fill} \r\n            theme={SwitchComponent.Themes[props.theme.toUpperCase()]} disabled={props.disabled} className={props.className} \r\n            size={SwitchComponent.Sizes[props.size.toUpperCase()]} style={props.style}/>)\r\n    }\r\n\r\n    onChange(value){\r\n        this.props.onChange(!this.state.value)\r\n        this.setState({\r\n            value: !this.state.value\r\n        })\r\n    }\r\n\r\n    get value(){\r\n        return this.state.value\r\n    }\r\n\r\n    static defaultProps = {\r\n        id: null,\r\n        onChange: NOOP,\r\n        value: false,\r\n        fill: null,\r\n        theme: \"default\",\r\n        disabled: false,\r\n        className: null,\r\n        size: \"default\",\r\n        style: {}\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([{onChange: (value) => {}}])\r\n            AllPreviews.push([{\r\n                value: false\r\n            }], [{\r\n                theme: \"default\"\r\n            }, {\r\n                theme: \"clear\"\r\n            }], [{\r\n                disabled: false\r\n            }, {\r\n                disabled: true\r\n            }], [{\r\n                id: \"api-preview-switch\"\r\n            }], [{\r\n                fill: null\r\n            }], [{\r\n                size: \"default\"\r\n            }, {\r\n                size: \"mini\"\r\n            }], [{\r\n                style: {}\r\n            }])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n\r\n    static help = {\r\n        error: \"The `clear` option doesn't work well on light theme.\"\r\n    }\r\n}\r\nlet AllPreviews","import WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport NOOP from \"../../modules/noop\"\r\nimport Utils from \"../../modules/Utils\"\r\n\r\ntype TextAreaProps = {\r\n    name?: string,\r\n    disabled?: boolean,\r\n    placeholder?: string,\r\n    autoFocus?: boolean,\r\n    resizeable?: boolean,\r\n    flex?: boolean,\r\n    autosize?: false,\r\n    rows?: number,\r\n    value?: string,\r\n    error?: string,\r\n    maxLength?: number,\r\n    className?: string,\r\n    id?: string,\r\n    onChange?: (value: string, name: string) => void,\r\n    onFocus?: (ev, name: string) => void,\r\n    onBlur?: (ev, name: string) => void,\r\n    onKeyDown?: (ev) => void\r\n}\r\n\r\nlet TextAreaModules\r\nexport default class TextArea extends React.Component<TextAreaProps, {value: string}> {\r\n    constructor(props:TextAreaProps){\r\n        super(props)\r\n\r\n        this.onChange = this.onChange.bind(this)\r\n        this.onFocus = this.onFocus.bind(this)\r\n        this.onBlur = this.onBlur.bind(this)\r\n        this.onKeyDown = this.onKeyDown.bind(this)\r\n\r\n        this.state = {\r\n            value: props.value || \"\"\r\n        }\r\n    }\r\n\r\n    get modules(){\r\n        return TextAreaModules || (TextAreaModules = [\r\n            WebpackLoader.find(e => e.default && e.default.displayName === \"TextArea\").default\r\n        ])\r\n    }\r\n\r\n    onChange(value, name){\r\n        this.props.onChange(value, name)\r\n        this.setState({\r\n            value\r\n        })\r\n    }\r\n\r\n    onFocus(ev, name){\r\n        this.props.onFocus(ev, name)\r\n    }\r\n\r\n    onBlur(ev, name){\r\n        this.props.onBlur(ev, name)\r\n    }\r\n    \r\n    onKeyDown(ev){\r\n        this.props.onKeyDown(ev)\r\n    }\r\n\r\n    render(){\r\n        let [\r\n            TextAreaComponent\r\n        ] = this.modules\r\n\r\n        let props = this.props\r\n\r\n        return <TextAreaComponent {...props} onChange={this.onChange} onFocus={this.onFocus} onBlur={this.onBlur} onKeyDown={this.onKeyDown} value={this.state.value}/>\r\n    }\r\n\r\n    get value(){\r\n        return this.state.value || \"\"\r\n    }\r\n\r\n    static defaultProps:TextAreaProps = {\r\n        name: null,\r\n        disabled: false,\r\n        placeholder: null,\r\n        autoFocus: false,\r\n        resizeable: false,\r\n        flex: false,\r\n        autosize: false,\r\n        rows: 3,\r\n        value: \"\",\r\n        error: null,\r\n        maxLength: null,\r\n        className: null,\r\n        id: null,\r\n        onChange: NOOP,\r\n        onFocus: NOOP,\r\n        onBlur: NOOP,\r\n        onKeyDown: NOOP\r\n    }\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([{\r\n                name: \"api-preview-textarea\"\r\n            }])\r\n            AllPreviews.push([{\r\n                disabled: false\r\n            }, {\r\n                disabled: true\r\n            }])\r\n            AllPreviews.push([{\r\n                placeholder: null\r\n            }])\r\n            AllPreviews.push([{\r\n                autoFocus: false\r\n            }, {\r\n                autoFocus: true\r\n            }])\r\n            AllPreviews.push([{\r\n                resizeable: false\r\n            }, {\r\n                resizeable: true\r\n            }])\r\n            AllPreviews.push([{\r\n                flex: false\r\n            }, {\r\n                flex: true\r\n            }])\r\n            AllPreviews.push([{\r\n                autosize: false\r\n            }, {\r\n                autosize: true\r\n            }])\r\n            AllPreviews.push([{\r\n                rows: 3\r\n            }, {\r\n                rows: 2\r\n            }, {\r\n                rows: 1\r\n            }])\r\n            AllPreviews.push([{\r\n                value: \"\"\r\n            }])\r\n            AllPreviews.push([{\r\n                error: null\r\n            }, {\r\n                error: \"Example error\"\r\n            }])\r\n            AllPreviews.push([{\r\n                maxLength: 100\r\n            }])\r\n            AllPreviews.push([{\r\n                className: \"\"\r\n            }])\r\n            AllPreviews.push([{\r\n                inputClassName: \"\"\r\n            }])\r\n            AllPreviews.push([{\r\n                id: \"api-preview-textarea\"\r\n            }])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n\r\n    static help = {\r\n        warn: \"This should be used for multi line inputs.\"\r\n    }\r\n}\r\nlet AllPreviews","import WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport NOOP from \"../../modules/noop\"\r\nimport Utils from \"../../modules/Utils\"\r\n\r\ntype TextInputProps = {\r\n    name?: string,\r\n    size?: \"default\"|\"mini\"\r\n    disabled?: boolean,\r\n    placeholder?: string,\r\n    value?: string,\r\n    error?: string,\r\n    maxLength?: number,\r\n    className?: string,\r\n    inputClassName?: string\r\n    id?: string,\r\n    onChange?: (value: string, name: string, input: TextInput) => void,\r\n    onFocus?: (ev, name: string, input: TextInput) => void,\r\n    onBlur?: (ev, name: string, input: TextInput) => void\r\n}\r\n\r\nlet TextInputModules\r\nexport default class TextInput extends React.PureComponent<TextInputProps, {value: string}> {\r\n    hasSet: boolean\r\n    constructor(props: TextInputProps){\r\n        super(props)\r\n\r\n        this.onChange = this.onChange.bind(this)\r\n        this.onFocus = this.onFocus.bind(this)\r\n        this.onBlur = this.onBlur.bind(this)\r\n\r\n        this.state = {\r\n            value: props.value || \"\"\r\n        }\r\n    }\r\n\r\n    static defaultProps:TextInputProps = {\r\n        name: \"\",\r\n        size: \"default\",\r\n        disabled: false,\r\n        placeholder: \"\",\r\n        value: \"\",\r\n        error: null,\r\n        maxLength: 999,\r\n        className: \"\",\r\n        inputClassName: \"\",\r\n        id: null,\r\n        onChange: NOOP,\r\n        onFocus: NOOP,\r\n        onBlur: NOOP\r\n    }\r\n\r\n    get modules(){\r\n        return TextInputModules || (TextInputModules = [\r\n            WebpackLoader.find(e => e.default && e.default.displayName === \"TextInput\").default\r\n        ])\r\n    }\r\n\r\n    onChange(value, name){\r\n        this.hasSet = false\r\n        this.props.onChange(value, name, this)\r\n        if(this.hasSet)return // prevent event if the onChange has changed the value.\r\n        this.setState({\r\n            value\r\n        })\r\n        this.forceUpdate()\r\n    }\r\n\r\n    onFocus(ev, name){\r\n        this.props.onFocus(ev, name, this)\r\n    }\r\n\r\n    onBlur(ev, name){\r\n        this.props.onBlur(ev, name, this)\r\n    }\r\n\r\n    render(){\r\n        let [\r\n            TextAreaComponent\r\n        ] = this.modules\r\n\r\n        let props = this.props\r\n        return <TextAreaComponent {...props} onChange={this.onChange} onFocus={this.onFocus} onBlur={this.onBlur} value={this.state.value} />\r\n    }\r\n\r\n    get value(){\r\n        return this.state.value || \"\"\r\n    }\r\n\r\n    setValue(value:string){\r\n        this.setState({\r\n            value: value\r\n        })\r\n        this.forceUpdate()\r\n        this.hasSet = true\r\n    }\r\n\r\n    static get AllPreviews(){\r\n        return AllPreviews || (() => {\r\n            AllPreviews = []\r\n            AllPreviews.push([{\r\n                name: \"api-preview-textinput\"\r\n            }], [{\r\n                size: \"default\"\r\n            }, {\r\n                size: \"mini\"\r\n            }], [{\r\n                disabled: false\r\n            }, {\r\n                disabled: true\r\n            }], [{\r\n                placeholder: \"\"\r\n            }], [{\r\n                value: \"\"\r\n            }], [{\r\n                error: null\r\n            }, {\r\n                error: \"Example error\"\r\n            }], [{\r\n                maxLength: 999\r\n            }], [{\r\n                className: \"\"\r\n            }], [{\r\n                inputClassName: \"\"\r\n            }], [{\r\n                id: \"api-preview-textinput\"\r\n            }], [{\r\n                onChange: (value: string, name: string) => {}\r\n            }])\r\n            return AllPreviews\r\n        })()\r\n    }\r\n\r\n    static help = {\r\n        warn: \"This should be used for single line inputs.\"\r\n    }\r\n}\r\nlet AllPreviews","import WebpackLoader from \"../../modules/WebpackLoader\"\r\nimport { notice, notices, events } from \"./Notices\"\r\nimport NOOP from \"../../modules/noop\"\r\n\r\nlet NoticeModules\r\nexport const defaultNotice:notice = {\r\n    text: \"\",\r\n    id: \"unknown id\",\r\n    onClick: NOOP,\r\n    buttonText: null,\r\n    type: \"default\"\r\n}\r\nexport default class Notice extends React.Component<notice> {\r\n    static displayName = \"LightcordNotice\"\r\n    static defaultProps:notice = defaultNotice\r\n\r\n    get modules(){\r\n        return NoticeModules || (NoticeModules = [\r\n            WebpackLoader.find(e => e.noticeInfo)\r\n        ])\r\n    }\r\n    \r\n    render(){\r\n        const [\r\n            noticeClasses\r\n        ] = this.modules\r\n\r\n        const className = noticeClasses[\"notice\"+this.props.type.slice(0, 1).toUpperCase()+this.props.type.slice(1)]\r\n            \r\n        if(!className){\r\n            notices.pop()\r\n            setImmediate(() => {\r\n                events.emit(\"noticeUpdate\")\r\n            })\r\n            return null\r\n        }\r\n        const button = this.props.buttonText ? <button className={noticeClasses.button} onClick={() => {\r\n            notices.pop()\r\n            this.props.onClick()\r\n            events.emit(\"noticeUpdate\")\r\n        }}>{this.props.buttonText}</button> : null\r\n        return <div className={className}>\r\n            <div className={noticeClasses.dismiss} role=\"button\" tabIndex={0} onClick={() => {\r\n                notices.pop()\r\n                events.emit(\"noticeUpdate\")\r\n            }} />\r\n            {this.props.text}\r\n            {button}\r\n        </div>\r\n    }\r\n}","import Notice from \"./Notice\"\r\nimport uuid from \"../../modules/uuid\"\r\nimport { EventEmitter } from \"events\"\r\n\r\nexport const events = new EventEmitter()\r\n\r\nexport default class Notices extends React.Component<{container: any}> {\r\n    static displayName = \"LightcordNotices\"\r\n    static defaultProps = {}\r\n    constructor(props: Readonly<{ container: any }>){\r\n        super(props)\r\n\r\n        this.noticeHandler = this.noticeHandler.bind(this)\r\n    }\r\n\r\n    noticeHandler(){\r\n        this.forceUpdate()\r\n    }\r\n\r\n    componentWillMount(){\r\n        events.on(\"noticeUpdate\", this.noticeHandler)\r\n    }\r\n\r\n    componentWillUnmount(){\r\n        events.off(\"noticeUpdate\", this.noticeHandler)\r\n    }\r\n\r\n    render(){\r\n        if(!this.hasNotice)return null\r\n        const notice = notices[0]\r\n        return <Notice {...notice}></Notice>\r\n    }\r\n\r\n    get hasNotice(){\r\n        return notices.length > 0\r\n    }\r\n}\r\n\r\nexport const notices:notice[] = []\r\n\r\nexport type noticeWithoutID = {\r\n    text: string,\r\n    buttonText?: string,\r\n    onClick?: () => void,\r\n    type: \"default\"|\"info\"|\"success\"|\"danger\"|\"streamerMode\"|\"download\"|\"notification\"|\"premium\"|\"richPresence\"|\"premiumTier1\"|\"premiumTier2\"|\"facebook\"|\"brand\"|\"survey\"|\"spotify\"\r\n}\r\n\r\nexport type notice = {\r\n    id: string\r\n} & noticeWithoutID","import WebpackLoader from \"./modules/WebpackLoader\"\r\nimport Components from \"./components/components\"\r\nimport uuid from \"./modules/uuid\"\r\nimport Utils from \"./modules/Utils\"\r\nimport DiscordTools from \"./modules/DiscordTools\"\r\nimport * as patchers from \"./modules/patchers\"\r\nimport excludeProperties from \"./modules/excludeProperties\"\r\nimport cloneNullProto from \"./modules/cloneNullProto\"\r\nimport NOOP from \"./modules/noop\"\r\nimport unfreeze from \"./modules/Unfreeze\"\r\npatchers.patch()\r\n\r\nconst LightcordApi = {\r\n    WebpackLoader: WebpackLoader,\r\n    Components: Components,\r\n    uuid: uuid,\r\n    Utils: Utils,\r\n    DiscordTools: DiscordTools,\r\n    _: {\r\n        excludeProperties: excludeProperties,\r\n        cloneNullProto: cloneNullProto,\r\n        NOOP: NOOP,\r\n        unfreeze: unfreeze\r\n    }\r\n}\r\n\r\ndeclare global {\r\n    var React:typeof import(\"react\")\r\n    interface Window {\r\n        Lightcord: LightcordGlobal,\r\n        BDModules: {\r\n            modules:any[],\r\n            get(filter:(mod:any)=>boolean, modules?:any[]):any[],\r\n            get(id:number, modules?:any[]):any,\r\n            get(ids: [number|((mod:any)=>boolean)], modules?:any[]):any\r\n        }\r\n    }\r\n    var Lightcord:LightcordGlobal\r\n}\r\n\r\nexport default LightcordApi\r\n\r\nObject.assign(window.Lightcord.Api, LightcordApi)\r\n\r\n/**\r\n * The main Lightcord exports. Can be accessed with `window.Lightcord`\r\n */\r\nexport interface LightcordGlobal {\r\n    DiscordModules: {\r\n        /**\r\n         * Internal Discord's dispatcher - can be used to subscribe to gateway events / client events.\r\n         */\r\n        dispatcher: import(\"./types/DiscordDispatcherTypes\").default,\r\n        constants: import(\"./types/DiscordConstantsTypes\").default\r\n    },\r\n    Settings: {\r\n        devMode: boolean,\r\n        callRingingBeat: boolean\r\n    },\r\n    Api: LightcordApiGlobal,\r\n    BetterDiscord: {\r\n        BdApi: typeof import(\"@bandagedbd/bdapi\").BdApi,\r\n        [mod:string]:any\r\n    }\r\n}\r\n\r\n/**\r\n * The main Api. Can be accessed with `window.Lightcord.Api`\r\n */\r\ntype LightcordApiGlobal = lightcordApiMainExports & typeof LightcordApi\r\n\r\ntype lightcordApiMainExports = {\r\n    /**\r\n     * Waits until the first module that match the filter gets exported\r\n     * @param filter The filter that specifies the module to match.\r\n     */\r\n    ensureExported(filter: (mod:any) => boolean):Promise<any>,\r\n    /**\r\n     * Recreate the object without the `__proto__` and `prototype` properties - usefull for better formatting in console.\r\n     * @param obj The object to recreate\r\n     */\r\n    cloneNullProto<Obj = any>(obj:Obj):Obj\r\n}","import { notices, noticeWithoutID, notice, events as noticeEvents } from \"../components/private/Notices\";\r\nimport Utils from \"./Utils\";\r\nimport uuid from \"./uuid\";\r\nimport cloneNullProto from \"./cloneNullProto\";\r\nimport { EventEmitter } from \"events\";\r\nimport { defaultNotice } from \"../components/private/Notice\";\r\nimport excludeProperties from \"./excludeProperties\";\r\nimport NOOP from \"./noop\";\r\nimport WebpackLoader, { WebpackLoaderError } from \"./WebpackLoader\";\r\n\r\nlet soundModule\r\nexport default new class DiscordTools {\r\n    showNotice(data:NoticeData):Notice{\r\n        if(typeof data !== \"object\" || typeof data.text !== \"string\")throw new Error(`This notice is not valid. Given: ${Utils.formatJSObject(data)}`)\r\n        let newData = cloneNullProto(Object.assign({}, defaultNotice, data)) as notice\r\n        newData.id = uuid()\r\n        notices.push(newData)\r\n        noticeEvents.emit(\"noticeUpdate\")\r\n        const notice = new Notice(newData)\r\n        return notice\r\n    }\r\n\r\n    get notices():Notice[]{\r\n        return notices.map(data => new Notice(data))\r\n    }\r\n\r\n    /**\r\n     * Quickly send notification (Even when no focused.)\r\n     * @param data The notification. Be sure to include all properties except functions cause they're optional.\r\n     * Notifications have a timeout of 3-5 seconds.\r\n     * They look like this: https://i.imgur.com/jzuxKKu.png\r\n     */\r\n    showNotification(data:NotificationData):Notification{\r\n        const notification = new window.Notification(data.title, excludeProperties(data, [\r\n            \"title\",\r\n            \"onClick\",\r\n            \"onClose\",\r\n            \"onShow\"\r\n        ]))\r\n        notification.onclick = data.onClick || NOOP\r\n        notification.onshow = data.onShow || NOOP\r\n        notification.onclose = data.onClose || NOOP\r\n        return notification\r\n    }\r\n\r\n    createSound(sound:Sound){\r\n        soundModule = soundModule || WebpackLoader.findByUniqueProperties([\"createSound\"])\r\n        if(!soundModule)throw new WebpackLoaderError(\"Couldn't find soundModule here.\")\r\n        const created = soundModule.createSound(sound)\r\n        return created\r\n    }\r\n\r\n    playSound(sound:Sound){\r\n        const created = this.createSound(sound)\r\n        created.play()\r\n        return created\r\n    }\r\n}\r\n\r\nexport type Sound = \"call_calling\"|\"call_ringing\"|\"call_ringing_beat\"|\"ddr-down\"|\"ddr-left\"|\"ddr-right\"|\"ddr-up\"|\"deafen\"|\"discodo\"|\"disconnect\"|\"human_man\"|\"mention1\"|\"mention2\"|\"mention3\"|\"message1\"|\"message2\"|\"message3\"|\"mute\"|\"overlayunlock\"|\"ptt_start\"|\"ptt_stop\"|\"reconnect\"|\"robot_man\"|\"stream_ended\"|\"stream_started\"|\"stream_user_joined\"|\"stream_user_left\"|\"undeafen\"|\"unmute\"|\"user_join\"|\"user_leave\"|\"user_moved\"\r\n\r\nexport type NotificationData = {\r\n    title: string,\r\n    body: string,\r\n    icon: string,\r\n    onShow?: () => void,\r\n    onClick?: () => void,\r\n    onClose?: () => void\r\n}\r\n\r\nexport type NoticeData = noticeWithoutID\r\n\r\nconst EventHandler = function(){\r\n    if(this.removed !== this.state.removed){\r\n        if(this.removed){\r\n            this.emit(\"removed\")\r\n        }\r\n    }\r\n    if(this.showing !== this.state.showing){\r\n        if(this.showing){\r\n            this.emit(\"showing\", true)\r\n        }else{\r\n            this.emit(\"showing\", false)\r\n        }\r\n    }\r\n    if(this.index !== this.state.index){\r\n        this.emit(\"index\", this.index)\r\n    }\r\n}\r\n\r\n/** A notice interface for modifying it and subscribing to events. */\r\nexport class Notice extends EventEmitter {\r\n    constructor(data){\r\n        super()\r\n        this.data = data\r\n\r\n        this.state = {\r\n            removed: this.removed,\r\n            showing: this.showing,\r\n            index: this.index\r\n        }\r\n\r\n        let eventFunc = EventHandler.bind(this)\r\n        noticeEvents.on(\"noticeUpdate\", eventFunc)\r\n        this.on(\"removed\", () => {\r\n            noticeEvents.off(\"noticeUpdate\", eventFunc)\r\n        })\r\n    }\r\n\r\n    /**\r\n     * Will be called whem the notice is removed.\r\n     */\r\n    on(event: \"removed\", listener: () => void):this\r\n    /**\r\n     * Will be called when the notice is visible or not.\r\n     */\r\n    on(event: \"showing\", listener: (isShowing:boolean) => void):this\r\n    /**\r\n     * Will be called when the notice queue changes.\r\n     */\r\n    on(event: \"index\", listener: (index:number) => void):this\r\n    on(event: string, listener: (...args:any[]) => void){\r\n        return super.on(event, listener)\r\n    }\r\n\r\n    /**\r\n     * Will be called whem the notice is removed.\r\n     */\r\n    once(event: \"removed\", listener: () => void):this\r\n    /**\r\n     * Will be called when the notice is visible or not.\r\n     */\r\n    once(event: \"showing\", listener: (isShowing:boolean) => void):this\r\n    /**\r\n     * Will be called when the notice queue changes.\r\n     */\r\n    once(event: \"index\", listener: (index:number) => void):this\r\n    once(event: string, listener: (...args:any[]) => void){\r\n        return super.once(event, listener)\r\n    }\r\n\r\n    off(event: \"removed\", listener: () => void):this\r\n    off(event: \"showing\", listener: (isShowing:boolean) => void):this\r\n    off(event: \"index\", listener: (index:number) => void):this\r\n    off(event: string, listener: (...args:any[]) => void){\r\n        return super.off(event, listener)\r\n    }\r\n\r\n    state:{\r\n        removed:boolean,\r\n        showing:boolean,\r\n        index:number\r\n    }\r\n\r\n    get removed():boolean{\r\n        return !notices.find(e => e.id === this.id)\r\n    }\r\n    get showing():boolean{\r\n        return this.index === 0\r\n    }\r\n\r\n    get index():number{\r\n        return notices.findIndex(e => e.id === this.id)\r\n    }\r\n    get id(){\r\n        return this.data.id\r\n    }\r\n\r\n    get text(){\r\n        return this.data.text\r\n    }\r\n    set text(text){\r\n        this.data.text = text\r\n        noticeEvents.emit(\"noticeUpdate\")\r\n    }\r\n\r\n    get type(){\r\n        return this.data.type\r\n    }\r\n    set type(type){\r\n        this.data.type = type\r\n        noticeEvents.emit(\"noticeUpdate\")\r\n    }\r\n\r\n    get buttonText(){\r\n        return this.data.buttonText\r\n    }\r\n    set buttonText(buttonText:string){\r\n        this.data.buttonText = buttonText\r\n        noticeEvents.emit(\"noticeUpdate\")\r\n    }\r\n\r\n    get onClick(){\r\n        return this.data.onClick\r\n    }\r\n    set onClick(onClick){\r\n        this.data.onClick = onClick\r\n        noticeEvents.emit(\"noticeUpdate\")\r\n    }\r\n\r\n    remove(){\r\n        if(this.removed)return\r\n        notices.splice(this.index, 1)\r\n        noticeEvents.emit(\"noticeUpdate\")\r\n    }\r\n    data:notice\r\n}","import components from \"../components/components\"\r\nimport Utils from \"./Utils\"\r\nimport { ComponentProps } from \"react\"\r\nimport uuid from \"./uuid\"\r\nimport TextInput from \"../components/inputs/TextInput\"\r\n\r\nexport default new class PluginUtilities {\r\n    constructor(){}\r\n\r\n    renderSettings(settings:SettingItem[]){\r\n        let items = this.renderSettingsToReact(settings)\r\n        let elem = React.createElement(\"div\", {key: uuid()}, items)\r\n        return Utils.ReactToHTMLElement(elem)\r\n    }\r\n\r\n    renderSettingsToReact(settings:SettingItem[]){\r\n        let items = []\r\n        settings.forEach(item => {\r\n            \r\n            if(typeof item !== \"object\")return items.push(item)\r\n            if(item.props && \"children\" in item.props){\r\n                if(!Array.isArray(item.props.children))item.props.children = [item.props.children]\r\n                item.props.children = this.renderSettingsToReact(item.props.children)\r\n            }\r\n            if(!item.props)item.props = {}\r\n            item.props.key = uuid()\r\n            let component = Utils.getNestedProps(components, item.component)\r\n            if(!component){\r\n                let warning = new TextInput({\r\n                    value: `Warning: No component was found for: \"${item.component}\". Please correct your code.`,\r\n                    disabled: true,\r\n                    error: `Warning: No component was found for: \"${item.component}\". Please correct your code.`\r\n                }).render()\r\n                items.push(warning)\r\n                return\r\n            }\r\n            items.push(React.createElement(component, Object.create(item.props)))\r\n        })\r\n        return items\r\n    }\r\n}\r\n\r\ntype SettingItem = {\r\n    component: string,\r\n    props: ComponentProps<any>\r\n}","export default function unfreeze(o) {\r\n    var oo = undefined;\r\n    if (o instanceof Array) {\r\n        oo = [];\r\n        var clone = function(v) {\r\n            oo.push(v)\r\n        };\r\n        o.forEach(clone);\r\n    } else if (o instanceof String) {\r\n        oo = new String(o).toString();\r\n    } else if (typeof o == 'object') {\r\n        oo = {};\r\n        for (var property in o) {\r\n            oo[property] = o[property];\r\n        }\r\n    }\r\n    return oo;\r\n}\r\ndeclare global {\r\n    interface ObjectConstructor {\r\n        unfreeze: <T extends any>(obj: Readonly<T>) => T\r\n    }\r\n}\r\nObject.unfreeze = unfreeze","import { ReactElement } from \"react\";\r\nimport ReactDOM = require(\"react-dom\")\r\nimport PluginUtilities from \"./PluginUtilities\";\r\n\r\nexport default new class Utils {\r\n    constructor(){}\r\n\r\n    ReactToHTMLElement(ReactElement: ReactElement){    \r\n        const element = document.createElement(\"div\")\r\n        ReactDOM.render(ReactElement, element)\r\n        return element\r\n    }\r\n\r\n    get PluginUtils(){return PluginUtilities}\r\n\r\n    getNestedProps(obj:any, path: string){\r\n        let segments = path.split(\".\")\r\n        for(let seg of segments){\r\n            obj = obj && (seg in obj) ? obj[seg] : undefined\r\n        }\r\n        return obj\r\n    }\r\n\r\n    DecimalColorToHex(color:number):string{\r\n        return \"#\"+color.toString(16).toUpperCase()\r\n    }\r\n\r\n    HexColorToDecimal(color:string):number{\r\n        color = color.replace(/[#;]/g, \"\")\r\n        let res = parseInt(color, 16)\r\n        if(isNaN(res))throw new Error(`Invalid color: ${color}`)\r\n        return res\r\n    }\r\n\r\n    removeDa(className:string):string{\r\n        if(!className)return className\r\n        return className.split(\" \").filter(e => !e.startsWith(\"da-\")).join(\" \")\r\n    }\r\n\r\n    FindReact(dom:Element, traverseUp:number = 0):React.Component|React.PureComponent{\r\n        // taken from https://stackoverflow.com/questions/29321742/react-getting-a-component-from-a-dom-element-for-debugging#39165137\r\n        const key = Object.keys(dom).find(key=>key.startsWith(\"__reactInternalInstance$\"));\r\n        const domFiber = dom[key];\r\n        if (domFiber == null) return null;\r\n    \r\n        // react <16\r\n        if (domFiber._currentElement) {\r\n            let compFiber = domFiber._currentElement._owner;\r\n            for (let i = 0; i < traverseUp; i++) {\r\n                compFiber = compFiber._currentElement._owner;\r\n            }\r\n            return compFiber._instance;\r\n        }\r\n    \r\n        // react 16+\r\n        const GetCompFiber = fiber=>{\r\n            //return fiber._debugOwner; // this also works, but is __DEV__ only\r\n            let parentFiber = fiber.return;\r\n            while (typeof parentFiber.type == \"string\") {\r\n                parentFiber = parentFiber.return;\r\n            }\r\n            return parentFiber;\r\n        };\r\n        let compFiber = GetCompFiber(domFiber);\r\n        for (let i = 0; i < traverseUp; i++) {\r\n            compFiber = GetCompFiber(compFiber);\r\n        }\r\n        return compFiber.stateNode;\r\n    }\r\n\r\n    hasClass(classNames:string, className:string):boolean{\r\n        if(!classNames || !className)return false\r\n        const classnames = classNames.split(\" \")\r\n        for(let classname of this.removeDa(className).split(\" \")){\r\n            if(!classnames.includes(classname))return false\r\n        }\r\n        return true\r\n    }\r\n\r\n    formatJSObject(obj:any):string{\r\n        if([\"string\", \"number\", \"boolean\", \"bigint\", \"undefined\"].includes(typeof obj))return JSON.stringify(obj)\r\n        if(obj === null)return \"null\"\r\n        if(typeof obj === \"function\")return String(obj)\r\n        if(typeof obj === \"symbol\")return String(obj)\r\n\r\n        if(Array.isArray(obj)){\r\n            if(!obj.length)return \"[]\"\r\n            return `[\\n    ${obj.map(e => this.formatJSObject(e)).join(\",\\n    \")}\\n]`\r\n        }else{\r\n            const keys = Object.keys(obj)\r\n            if(keys.length === 0)return \"{}\"\r\n            return `{\\n    ${keys.map(key => {\r\n                let original = key\r\n                if(typeof key === \"symbol\")key = \"[\"+String(key)+\"]\"\r\n                else{\r\n                    if(typeof key === \"number\")key = String(key)\r\n                    else{\r\n                        console.log(key)\r\n                        if(isNaN(parseInt(key[0]))){\r\n                            key = this.formatJSObject(key)\r\n                        }else if(/[^\\w\\d_$]/g.test(key)){\r\n                            key = this.formatJSObject(key)\r\n                        }\r\n                    }\r\n                }\r\n                return `${key}: ${this.formatJSObject(obj[original])}`\r\n            })}\\n}`\r\n        }\r\n    }\r\n}","const BDModules = window.BDModules\r\n\r\nexport default new class WebpackLoader {\r\n    constructor(){}\r\n\r\n    get(id: number):any{\r\n        return BDModules.get(id)\r\n    }\r\n    find(filter: (mod:any) => boolean):any{\r\n        let result = BDModules.get(filter)[0]\r\n        if(!result){\r\n            console.warn(filter, \"couldn't find the module.\")\r\n        }\r\n        return result\r\n    }\r\n    findByUniqueProperties(props:(string|number)[]):any{\r\n        return BDModules.get((mod) => {\r\n            if(mod.__esModule && (\"default\" in mod)){\r\n                let doesMatch = true\r\n                for(let prop of props){\r\n                    if(!Object.prototype.hasOwnProperty.call(mod.default, prop))doesMatch = false\r\n                }\r\n                if(doesMatch)return true\r\n            }\r\n            for(let prop of props){\r\n                if(!Object.prototype.hasOwnProperty.call(mod, prop))return false\r\n            }\r\n            return true\r\n        })[0]\r\n    }\r\n    filter(filter: (mod:any) => boolean):any[]{\r\n        return BDModules.get(filter)\r\n    }\r\n    filterByUniqueProperties(props:(string|number)[]):any{\r\n        return BDModules.get((mod) => {\r\n            if(mod.__esModule && (\"default\" in mod)){\r\n                let doesMatch = true\r\n                for(let prop of props){\r\n                    if(!Object.prototype.hasOwnProperty.call(mod.default, prop))doesMatch = false\r\n                }\r\n                if(doesMatch)return true\r\n            }\r\n            for(let prop of props){\r\n                if(!Object.prototype.hasOwnProperty.call(mod, prop))return false\r\n            }\r\n            return true\r\n        })\r\n    }\r\n}\r\n\r\nexport class WebpackLoaderError extends Error {\r\n    constructor(message:string = \"\"){\r\n        message += \"\\n\\tThis error is related to Lightcord not being able to find a WebpackModule. \\n\\tPlease show this error and a few lines of logs above this error. \\n\\tOpen an issue on https://github.com/Lightcord/Lightcord or in their discord server.\"\r\n        super(message)\r\n        this.name = \"WebpackLoaderError\"\r\n    }\r\n}","/**\r\n * Recreate the given object without the __proto__. Useful for better formatting when output in console.\r\n * @param obj The object to recreate\r\n */\r\nexport default function cloneNullProto<Obj=any>(obj:Obj):Obj{\r\n    let o = Object.create(null)\r\n    Object.keys(obj).forEach(k => {\r\n        o[k] = obj[k]\r\n    })\r\n    return o\r\n}","export default function excludeProperties<Obj = any>(obj:Obj, props:(keyof Obj)[]):Partial<Obj>{\r\n    let newObj = {}\r\n\r\n    Object.keys(obj).forEach((k) => {\r\n        if(props.includes(k as keyof Obj))return\r\n        newObj[k] = obj[k]\r\n    })\r\n\r\n    return newObj\r\n}","export default function NOOP(){}","import Utils from \"./Utils\"\r\nimport Notices, { notices } from \"../components/private/Notices\"\r\n\r\nexport function patch(){\r\n    /** START NOTICE */\r\n    getModule(e => e.default && e.default.displayName === \"ConnectedAppView\")\r\n    .then(async (mod) => {\r\n        const appClasses = await getModule(e => e.hasNotice);\r\n        const buildRender = original => {\r\n            return function render(){\r\n                const returnValue = original.call(this, ...arguments)\r\n                const newchildren = []\r\n                let children = returnValue.props.children[1].props.children\r\n                if(!Array.isArray(children))children = [children]\r\n    \r\n                newchildren.push(children[0])\r\n                newchildren.push(React.createElement(Notices, {container: this}))\r\n                newchildren.push(children[1])\r\n                returnValue.props.children[1].props.children = newchildren\r\n                \r\n                returnValue.props.children[1].props.children[2].props.children[0].props.render = buildRenderChannelSidebar(returnValue.props.children[1].props.children[2].props.children[0].props.render)\r\n                \r\n                return returnValue\r\n            }\r\n        }\r\n        const buildRenderChannelSidebar = original => {\r\n            return function renderChannelSidebar(){\r\n                const returnValue = original.call(this, ...arguments)\r\n                \r\n                const hasNotice = notices.length > 0\r\n                if(!hasNotice)return returnValue\r\n                if(!Utils.hasClass(returnValue.props.className, appClasses.hasNotice)){\r\n                    returnValue.props.className += \" \"+Utils.removeDa(appClasses.hasNotice)\r\n                }\r\n\r\n                return returnValue\r\n            }\r\n        }\r\n        mod.default.prototype.render = buildRender(mod.default.prototype.render);\r\n        (async function(){\r\n            const base = document.querySelector(\".\"+Utils.removeDa(appClasses.base))\r\n            if(!base)throw new Error(`Could not find base here`)\r\n            const elem = Utils.FindReact(base) as any\r\n            elem.render = buildRender(elem.render)\r\n            elem.forceUpdate()\r\n        })()\r\n    })\r\n    /** END NOTICE */\r\n\r\n    /** START IN-APP NOTIFICATIONS */\r\n    //getModule(e => true)\r\n    /** END IN-APP NOTIFICATIONS */\r\n}\r\n\r\nfunction getModule(filter: (mod:any) => boolean):Promise<any>{\r\n    return new Promise((resolve) => {\r\n        window.Lightcord.Api.ensureExported(filter)\r\n        .then(resolve)\r\n        .catch(err => {\r\n            console.error(\"[LIGHTCORD]\", err, filter)\r\n        })\r\n    })\r\n}","import * as uuidv1 from \"uuid/v1\"\r\nimport * as uuidv4 from \"uuid/v4\"\r\n\r\ntype uuidFunc = () => string\r\nlet uuid:uuidFunc & {v1: uuidFunc, v4: uuidFunc} = Object.assign(function(){\r\n    return uuidv4()\r\n}, {v1: () => uuidv1(), v4: () => uuidv4()})\r\n\r\nexport default uuid","module.exports = require(\"events\");","module.exports = require(\"uuid/v1\");","module.exports = require(\"uuid/v4\");"],"sourceRoot":""}