2018-10-11 10:21:26 +02:00
|
|
|
|
module.exports = (Plugin, Api, Vendor) => {
|
2019-01-26 22:45:19 +01:00
|
|
|
|
if (!global.BDFDB || typeof BDFDB != "object") global.BDFDB = {BDv2Api: Api};
|
2018-10-11 10:21:26 +02:00
|
|
|
|
|
|
|
|
|
return class extends Plugin {
|
|
|
|
|
initConstructor () {
|
|
|
|
|
this.labels = {};
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
this.patchModules = {
|
|
|
|
|
"ChannelTextArea":"componentDidMount",
|
|
|
|
|
"AuditLog":"componentDidMount",
|
|
|
|
|
"ChannelCategoryItem":"componentDidMount",
|
|
|
|
|
"ChannelItem":"componentDidMount",
|
|
|
|
|
"HeaderBar":["componentDidMount","componentDidUpdate"],
|
|
|
|
|
"Clickable":"componentDidMount"
|
|
|
|
|
};
|
|
|
|
|
|
2018-10-11 10:21:26 +02:00
|
|
|
|
this.channelContextEntryMarkup =
|
|
|
|
|
`<div class="${BDFDB.disCN.contextmenuitemgroup}">
|
|
|
|
|
<div class="${BDFDB.disCN.contextmenuitem} localchannelsettings-item ${BDFDB.disCN.contextmenuitemsubmenu}">
|
2019-01-02 22:08:55 +01:00
|
|
|
|
<span class="DevilBro-textscrollwrapper" speed=3><div class="DevilBro-textscroll">REPLACE_context_localchannelsettings_text</div></span>
|
2018-10-11 10:21:26 +02:00
|
|
|
|
<div class="${BDFDB.disCN.contextmenuhint}"></div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>`;
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2018-10-11 10:21:26 +02:00
|
|
|
|
this.channelContextSubMenuMarkup =
|
|
|
|
|
`<div class="${BDFDB.disCN.contextmenu} editchannels-submenu">
|
|
|
|
|
<div class="${BDFDB.disCN.contextmenuitemgroup}">
|
|
|
|
|
<div class="${BDFDB.disCN.contextmenuitem} channelsettings-item">
|
2019-01-02 22:08:55 +01:00
|
|
|
|
<span class="DevilBro-textscrollwrapper" speed=3><div class="DevilBro-textscroll">REPLACE_submenu_channelsettings_text</div></span>
|
2018-10-11 10:21:26 +02:00
|
|
|
|
<div class="${BDFDB.disCN.contextmenuhint}"></div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="${BDFDB.disCN.contextmenuitem} resetsettings-item ${BDFDB.disCN.contextmenuitemdisabled}">
|
2019-01-02 22:08:55 +01:00
|
|
|
|
<span class="DevilBro-textscrollwrapper" speed=3><div class="DevilBro-textscroll">REPLACE_submenu_resetsettings_text</div></span>
|
2018-10-11 10:21:26 +02:00
|
|
|
|
<div class="${BDFDB.disCN.contextmenuhint}"></div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>`;
|
|
|
|
|
|
|
|
|
|
this.channelSettingsModalMarkup =
|
2019-01-26 23:54:46 +01:00
|
|
|
|
`<span class="${this.name}-modal DevilBro-modal">
|
2018-10-11 10:21:26 +02:00
|
|
|
|
<div class="${BDFDB.disCN.backdrop}"></div>
|
|
|
|
|
<div class="${BDFDB.disCN.modal}">
|
|
|
|
|
<div class="${BDFDB.disCN.modalinner}">
|
|
|
|
|
<div class="${BDFDB.disCNS.modalsub + BDFDB.disCN.modalsizemedium}">
|
|
|
|
|
<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.modalheader}" style="flex: 0 0 auto;">
|
|
|
|
|
<div class="${BDFDB.disCN.flexchild}" style="flex: 1 1 auto;">
|
|
|
|
|
<h4 class="${BDFDB.disCNS.h4 + BDFDB.disCNS.headertitle + BDFDB.disCNS.size16 + BDFDB.disCNS.height20 + BDFDB.disCNS.weightsemibold + BDFDB.disCNS.defaultcolor + BDFDB.disCNS.h4defaultmargin + BDFDB.disCN.marginreset}">REPLACE_modal_header_text</h4>
|
|
|
|
|
<div class="${BDFDB.disCNS.modalguildname + BDFDB.disCNS.small + BDFDB.disCNS.size12 + BDFDB.disCNS.height16 + BDFDB.disCN.primary}"></div>
|
|
|
|
|
</div>
|
2019-01-26 23:54:46 +01:00
|
|
|
|
<button type="button" class="${BDFDB.disCNS.modalclose + BDFDB.disCNS.flexchild + BDFDB.disCNS.button + BDFDB.disCNS.buttonlookblank + BDFDB.disCNS.buttoncolorbrand + BDFDB.disCN.buttongrow}">
|
|
|
|
|
<div class="${BDFDB.disCN.buttoncontents}">
|
|
|
|
|
<svg name="Close" width="18" height="18" viewBox="0 0 12 12" style="flex: 0 1 auto;">
|
|
|
|
|
<g fill="none" fill-rule="evenodd">
|
|
|
|
|
<path d="M0 0h12v12H0"></path>
|
|
|
|
|
<path class="fill" fill="currentColor" d="M9.5 3.205L8.795 2.5 6 5.295 3.205 2.5l-.705.705L5.295 6 2.5 8.795l.705.705L6 6.705 8.795 9.5l.705-.705L6.705 6"></path>
|
|
|
|
|
</g>
|
|
|
|
|
</svg>
|
|
|
|
|
</div>
|
|
|
|
|
</button>
|
2018-10-11 10:21:26 +02:00
|
|
|
|
</div>
|
|
|
|
|
<div class="${BDFDB.disCNS.scrollerwrap + BDFDB.disCNS.modalcontent + BDFDB.disCNS.scrollerthemed + BDFDB.disCN.themeghosthairline}">
|
|
|
|
|
<div class="${BDFDB.disCNS.scroller + BDFDB.disCN.modalsubinner}">
|
|
|
|
|
<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.vertical + BDFDB.disCNS.directioncolumn + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom20}" style="flex: 1 1 auto;">
|
|
|
|
|
<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom8}" style="flex: 1 1 auto;">
|
|
|
|
|
<h3 class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style="flex: 0 0 auto;">REPLACE_modal_channelname_text</h3>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom8}" style="flex: 1 1 auto;">
|
|
|
|
|
<div class="${BDFDB.disCNS.inputwrapper + BDFDB.disCNS.vertical + BDFDB.disCNS.flex + BDFDB.disCNS.directioncolumn + BDFDB.disCN.flexchild}" style="flex: 1 1 auto;"><input type="text" class="${BDFDB.disCNS.inputdefault + BDFDB.disCNS.input + BDFDB.disCN.size16}" id="input-channelname"></div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="${BDFDB.disCNS.modaldivider + BDFDB.disCNS.modaldividerdefault + BDFDB.disCN.margintop20}"></div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.vertical + BDFDB.disCNS.directioncolumn + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom20}" style="flex: 1 1 auto;">
|
|
|
|
|
<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.vertical + BDFDB.disCNS.directioncolumn + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstart + BDFDB.disCN.nowrap}" style="flex: 1 1 auto;">
|
|
|
|
|
<h3 class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style="flex: 0 0 auto;">REPLACE_modal_colorpicker1_text</h3>
|
|
|
|
|
</div>
|
2019-01-26 23:54:46 +01:00
|
|
|
|
<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom8} swatches" style="flex: 1 1 auto;"></div>
|
2018-10-11 10:21:26 +02:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontalreverse + BDFDB.disCNS.horizontalreverse2 + BDFDB.disCNS.directionrowreverse + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCNS.nowrap + BDFDB.disCN.modalfooter}">
|
|
|
|
|
<button type="button" class="btn-save ${BDFDB.disCNS.button + BDFDB.disCNS.buttonlookfilled + BDFDB.disCNS.buttoncolorbrand + BDFDB.disCNS.buttonsizemedium + BDFDB.disCN.buttongrow}">
|
|
|
|
|
<div class="${BDFDB.disCN.buttoncontents}">REPLACE_btn_save_text</div>
|
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</span>`;
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
this.css = `
|
|
|
|
|
${BDFDB.dotCN.channelheadertitletext}[custom-editchannelsheader] ${BDFDB.dotCN.channelheaderchannelicon} {
|
|
|
|
|
opacity: 0.6;
|
|
|
|
|
}
|
|
|
|
|
`;
|
|
|
|
|
|
2018-10-11 10:21:26 +02:00
|
|
|
|
this.defaults = {
|
|
|
|
|
settings: {
|
2019-01-26 23:54:46 +01:00
|
|
|
|
changeChannelIcon: {value:true, description:"Change color of Channel Icon."},
|
|
|
|
|
changeUnreadIndicator: {value:true, description:"Change color of Unread Indicator."}
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2018-10-11 10:21:26 +02:00
|
|
|
|
onStart () {
|
2019-01-26 22:45:19 +01:00
|
|
|
|
var libraryScript = document.querySelector('head script[src="https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.js"]');
|
|
|
|
|
if (!libraryScript || performance.now() - libraryScript.getAttribute("date") > 600000) {
|
2018-10-11 10:21:26 +02:00
|
|
|
|
if (libraryScript) libraryScript.remove();
|
|
|
|
|
libraryScript = document.createElement("script");
|
|
|
|
|
libraryScript.setAttribute("type", "text/javascript");
|
|
|
|
|
libraryScript.setAttribute("src", "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.js");
|
2019-01-26 22:45:19 +01:00
|
|
|
|
libraryScript.setAttribute("date", performance.now());
|
2019-01-30 21:23:49 +01:00
|
|
|
|
libraryScript.addEventListener("load", () => {if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) this.initialize();});
|
2018-10-11 10:21:26 +02:00
|
|
|
|
document.head.appendChild(libraryScript);
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
else if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) this.initialize();
|
2018-10-11 10:21:26 +02:00
|
|
|
|
this.startTimeout = setTimeout(() => {this.initialize();}, 30000);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
initialize () {
|
2019-01-26 22:45:19 +01:00
|
|
|
|
if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) {
|
2019-01-26 23:54:46 +01:00
|
|
|
|
if (this.started) return true;
|
2018-10-11 10:21:26 +02:00
|
|
|
|
BDFDB.loadMessage(this);
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
this.UserUtils = BDFDB.WebModules.findByProperties("getUsers","getUser");
|
|
|
|
|
this.ChannelUtils = BDFDB.WebModules.findByProperties("getChannels","getChannel");
|
|
|
|
|
this.CurrentChannelUtils = BDFDB.WebModules.findByProperties("getChannels","getDefaultChannel");
|
|
|
|
|
this.LastGuildStore = BDFDB.WebModules.findByProperties("getLastSelectedGuildId");
|
|
|
|
|
this.LastChannelStore = BDFDB.WebModules.findByProperties("getLastSelectedChannelId");
|
2018-10-11 10:21:26 +02:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
BDFDB.WebModules.forceAllUpdates(this);
|
2018-10-11 10:21:26 +02:00
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
else {
|
2019-01-24 13:37:08 +01:00
|
|
|
|
console.error(`%c[${this.name}]%c`, 'color: #3a71c1; font-weight: 700;', '', 'Fatal Error: Could not load BD functions!');
|
2018-10-11 10:21:26 +02:00
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
onStop () {
|
2019-01-26 22:45:19 +01:00
|
|
|
|
if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) {
|
2019-01-26 23:54:46 +01:00
|
|
|
|
let data = BDFDB.loadAllData(this, "channels");
|
|
|
|
|
BDFDB.removeAllData(this, "channels");
|
|
|
|
|
BDFDB.WebModules.forceAllUpdates(this);
|
|
|
|
|
BDFDB.saveAllData(data, this, "channels");
|
|
|
|
|
|
|
|
|
|
BDFDB.removeEles(".autocompleteEditChannels", ".autocompleteEditChannelsRow");
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2018-10-11 10:21:26 +02:00
|
|
|
|
BDFDB.unloadMessage(this);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
|
|
|
|
|
2018-10-11 10:21:26 +02:00
|
|
|
|
// begin of own functions
|
|
|
|
|
|
|
|
|
|
changeLanguageStrings () {
|
|
|
|
|
this.channelContextEntryMarkup = this.channelContextEntryMarkup.replace("REPLACE_context_localchannelsettings_text", this.labels.context_localchannelsettings_text);
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2018-10-11 10:21:26 +02:00
|
|
|
|
this.channelContextSubMenuMarkup = this.channelContextSubMenuMarkup.replace("REPLACE_submenu_channelsettings_text", this.labels.submenu_channelsettings_text);
|
|
|
|
|
this.channelContextSubMenuMarkup = this.channelContextSubMenuMarkup.replace("REPLACE_submenu_resetsettings_text", this.labels.submenu_resetsettings_text);
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2018-10-11 10:21:26 +02:00
|
|
|
|
this.channelSettingsModalMarkup = this.channelSettingsModalMarkup.replace("REPLACE_modal_header_text", this.labels.modal_header_text);
|
|
|
|
|
this.channelSettingsModalMarkup = this.channelSettingsModalMarkup.replace("REPLACE_modal_channelname_text", this.labels.modal_channelname_text);
|
|
|
|
|
this.channelSettingsModalMarkup = this.channelSettingsModalMarkup.replace("REPLACE_modal_colorpicker1_text", this.labels.modal_colorpicker1_text);
|
|
|
|
|
this.channelSettingsModalMarkup = this.channelSettingsModalMarkup.replace("REPLACE_btn_save_text", this.labels.btn_save_text);
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
onChannelContextMenu (instance, menu) {
|
|
|
|
|
if (instance.props && instance.props.channel && !menu.querySelector(".localchannelsettings-item")) {
|
|
|
|
|
let channelContextEntry = BDFDB.htmlToElement(this.channelContextEntryMarkup);
|
|
|
|
|
menu.appendChild(channelContextEntry);
|
|
|
|
|
let settingsitem = channelContextEntry.querySelector(".localchannelsettings-item");
|
|
|
|
|
settingsitem.addEventListener("mouseenter", () => {
|
|
|
|
|
let channelContextSubMenu = BDFDB.htmlToElement(this.channelContextSubMenuMarkup);
|
|
|
|
|
let channelitem = channelContextSubMenu.querySelector(".channelsettings-item");
|
|
|
|
|
channelitem.addEventListener("click", () => {
|
|
|
|
|
instance._reactInternalFiber.return.memoizedProps.closeContextMenu();
|
|
|
|
|
this.showChannelSettings(instance.props.channel);
|
2018-10-11 10:21:26 +02:00
|
|
|
|
});
|
2019-01-26 23:54:46 +01:00
|
|
|
|
if (BDFDB.loadData(instance.props.channel.id, this, "channels")) {
|
|
|
|
|
let resetitem = channelContextSubMenu.querySelector(".resetsettings-item");
|
|
|
|
|
BDFDB.removeClass(resetitem, BDFDB.disCN.contextmenuitemdisabled);
|
|
|
|
|
resetitem.addEventListener("click", () => {
|
|
|
|
|
instance._reactInternalFiber.return.memoizedProps.closeContextMenu();
|
|
|
|
|
BDFDB.removeData(instance.props.channel.id, this, "channels");
|
|
|
|
|
BDFDB.WebModules.forceAllUpdates(this);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
BDFDB.appendSubMenu(settingsitem, channelContextSubMenu);
|
|
|
|
|
});
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
showChannelSettings (info) {
|
|
|
|
|
var {name,color} = BDFDB.loadData(info.id, this, "channels") || {}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
let channelSettingsModal = BDFDB.htmlToElement(this.channelSettingsModalMarkup);
|
|
|
|
|
let channelnameinput = channelSettingsModal.querySelector("#input-channelname");
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
channelSettingsModal.querySelector(BDFDB.dotCN.modalguildname).innerText = info.name;
|
|
|
|
|
channelnameinput.value = name || "";
|
|
|
|
|
channelnameinput.setAttribute("placeholder", info.name);
|
|
|
|
|
BDFDB.setColorSwatches(channelSettingsModal, color);
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
BDFDB.appendModal(channelSettingsModal);
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
BDFDB.addChildEventListener(channelSettingsModal, "click", ".btn-save", e => {
|
|
|
|
|
e.preventDefault();
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
name = channelnameinput.value.trim();
|
|
|
|
|
name = name ? name : null;
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
color = BDFDB.getSwatchColor(channelSettingsModal, 1);
|
|
|
|
|
if (color) {
|
|
|
|
|
if (color[0] < 30 && color[1] < 30 && color[2] < 30) color = BDFDB.colorCHANGE(color, 30);
|
|
|
|
|
else if (color[0] > 225 && color[1] > 225 && color[2] > 225) color = BDFDB.colorCHANGE(color, -30);
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
if (name == null && color == null) {
|
|
|
|
|
BDFDB.removeData(info.id, this, "channels");
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
BDFDB.saveData(info.id, {name,color}, this, "channels");
|
|
|
|
|
}
|
|
|
|
|
BDFDB.WebModules.forceAllUpdates(this);
|
|
|
|
|
});
|
|
|
|
|
channelnameinput.focus();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
processChannelTextArea (instance, wrapper) {
|
|
|
|
|
let channel = BDFDB.getReactValue(instance, "props.channel");
|
|
|
|
|
if (channel) {
|
|
|
|
|
var textarea = wrapper.querySelector("textarea");
|
|
|
|
|
if (!textarea) return;
|
|
|
|
|
if (channel.type == 0 && instance.props.type == "normal") {
|
|
|
|
|
let data = BDFDB.loadData(channel.id, this, "channels") || {};
|
|
|
|
|
wrapper.querySelector("textarea").setAttribute("placeholder", BDFDB.LanguageStrings.TEXTAREA_PLACEHOLDER.replace("{{channel}}", "#" + (data.name || channel.name)));
|
|
|
|
|
}
|
|
|
|
|
BDFDB.addEventListener(this, textarea, "keydown", e => {
|
|
|
|
|
let autocompletemenu = textarea.parentElement.querySelector(BDFDB.dotCN.autocomplete);
|
|
|
|
|
if (autocompletemenu && (e.which == 9 || e.which == 13)) {
|
|
|
|
|
if (BDFDB.containsClass(autocompletemenu.querySelector(BDFDB.dotCN.autocompleteselected).parentElement, "autocompleteEditChannelsRow")) {
|
|
|
|
|
e.originalEvent.preventDefault();
|
|
|
|
|
e.originalEvent.stopPropagation();
|
|
|
|
|
this.swapWordWithMention(textarea);
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-26 23:54:46 +01:00
|
|
|
|
else if (autocompletemenu && (e.which == 38 || e.which == 40)) {
|
|
|
|
|
let autocompleteitems = autocompletemenu.querySelectorAll(BDFDB.dotCN.autocompleteselectable + ":not(.autocompleteEditChannelsSelector)");
|
|
|
|
|
let selected = autocompletemenu.querySelector(BDFDB.dotCN.autocompleteselected);
|
|
|
|
|
if (BDFDB.containsClass(selected, "autocompleteEditChannelsSelector") || autocompleteitems[e.which == 38 ? 0 : (autocompleteitems.length-1)] == selected) {
|
|
|
|
|
e.originalEvent.preventDefault();
|
|
|
|
|
e.originalEvent.stopPropagation();
|
|
|
|
|
let next = this.getNextSelection(autocompletemenu, null, e.which == 38 ? false : true);
|
|
|
|
|
BDFDB.removeClass(selected, BDFDB.disCN.autocompleteselected);
|
|
|
|
|
BDFDB.addClass(selected, BDFDB.disCN.autocompleteselector);
|
|
|
|
|
BDFDB.addClass(next, BDFDB.disCN.autocompleteselected);
|
|
|
|
|
}
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
2019-01-26 23:54:46 +01:00
|
|
|
|
else if (textarea.value && !e.shiftKey && e.which == 13 && !autocompletemenu && textarea.value.indexOf("s/") != 0) {
|
|
|
|
|
this.format = true;
|
|
|
|
|
textarea.dispatchEvent(new Event("input"));
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
2019-01-26 23:54:46 +01:00
|
|
|
|
else if (!e.ctrlKey && e.which != 16 && textarea.selectionStart == textarea.selectionEnd && textarea.selectionEnd == textarea.value.length) {
|
|
|
|
|
clearTimeout(textarea.EditChannelsAutocompleteTimeout);
|
|
|
|
|
textarea.EditChannelsAutocompleteTimeout = setTimeout(() => {this.addAutoCompleteMenu(textarea, channel);},100);
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
if (!e.ctrlKey && e.which != 38 && e.which != 40 && !(e.which == 39 && textarea.selectionStart == textarea.selectionEnd && textarea.selectionEnd == textarea.value.length)) BDFDB.removeEles(".autocompleteEditChannels", ".autocompleteEditChannelsRow");
|
|
|
|
|
});
|
|
|
|
|
BDFDB.addEventListener(this, textarea, "click", e => {
|
|
|
|
|
if (textarea.selectionStart == textarea.selectionEnd && textarea.selectionEnd == textarea.value.length) setImmediate(() => {this.addAutoCompleteMenu(textarea, channel);});
|
|
|
|
|
});
|
|
|
|
|
}
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
processAuditLog (instance, wrapper) {
|
|
|
|
|
let channel = BDFDB.getReactValue(instance, "props.log.options.channel");
|
|
|
|
|
if (channel) {
|
|
|
|
|
let hooks = wrapper.querySelectorAll(`${BDFDB.dotCN.flexchild} > span${BDFDB.notCN.auditloguserhook}`);
|
|
|
|
|
if (hooks.length > 0) this.changeChannel2(channel, hooks[0].firstChild);
|
|
|
|
|
}
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
processChannelCategoryItem (instance, wrapper) {
|
|
|
|
|
if (instance.props && instance.props.channel) {
|
|
|
|
|
this.changeChannel(instance.props.channel, wrapper.querySelector(BDFDB.dotCN.categorycolortransition));
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
processChannelItem (instance, wrapper) {
|
|
|
|
|
if (instance.props && instance.props.channel) {
|
|
|
|
|
this.changeChannel(instance.props.channel, wrapper.querySelector(BDFDB.dotCN.channelname));
|
|
|
|
|
}
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
processHeaderBar (instance, wrapper) {
|
|
|
|
|
let channel_id = BDFDB.getReactValue(instance, "_reactInternalFiber.return.memoizedProps.channelId");
|
|
|
|
|
if (channel_id) {
|
|
|
|
|
let channelname = wrapper.querySelector(BDFDB.dotCN.channelheaderchannelname);
|
|
|
|
|
if (channelname) {
|
|
|
|
|
let channel = this.ChannelUtils.getChannel(channel_id);
|
|
|
|
|
if (channel) {
|
|
|
|
|
if (channel.type == 0) this.changeChannel(channel, wrapper.querySelector(BDFDB.dotCN.channelheaderchannelname));
|
|
|
|
|
else {
|
|
|
|
|
if (channel.type == 1) channel = this.UserUtils.getUser(channel.recipients[0]) || channel;
|
|
|
|
|
if (channelname.EditChannelsChangeObserver && typeof channelname.EditChannelsChangeObserver.disconnect == "function") channelname.EditChannelsChangeObserver.disconnect();
|
|
|
|
|
channelname.style.removeProperty("color");
|
|
|
|
|
channelname.style.removeProperty("background");
|
|
|
|
|
BDFDB.setInnerText(channelname, channel.name || channel.username);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
processClickable (instance, wrapper) {
|
|
|
|
|
if (!instance.props || !instance.props.className) return;
|
|
|
|
|
else if (instance.props.tag == "span" && instance.props.className.indexOf(BDFDB.disCN.mentionwrapper) > -1 && instance.props.className.indexOf(BDFDB.disCN.mention) == -1) {
|
|
|
|
|
let children = BDFDB.getReactValue(instance, "_reactInternalFiber.memoizedProps.children");
|
|
|
|
|
if (children && typeof children[0] == "string") {
|
|
|
|
|
let channelname = children[0].slice(1);
|
|
|
|
|
let categoryname = BDFDB.getReactValue(instance, "_reactInternalFiber.return.return.type.displayName") == "Tooltip" ? BDFDB.getReactValue(instance, "_reactInternalFiber.return.return.memoizedProps.text") : null;
|
|
|
|
|
for (let channel of this.CurrentChannelUtils.getChannels(this.LastGuildStore.getGuildId())[0]) {
|
|
|
|
|
if (channelname == channel.channel.name) {
|
|
|
|
|
let category = categoryname ? this.ChannelUtils.getChannel(channel.channel.parent_id) : null;
|
|
|
|
|
if (!category || category && categoryname == category.name) {
|
|
|
|
|
this.changeMention(channel.channel, wrapper, category || {});
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else if (instance.props.tag == "div" && instance.props.className.indexOf(BDFDB.disCN.quickswitchresult) > -1) {
|
|
|
|
|
let result = BDFDB.getReactValue(instance, "_reactInternalFiber.return.memoizedProps.result");
|
|
|
|
|
if (result && result.type.indexOf("_CHANNEL") != -1) {
|
|
|
|
|
this.changeChannel(result.record, wrapper.querySelector(BDFDB.dotCN.quickswitchresultmatch));
|
|
|
|
|
if (result.record.parent_id) {
|
|
|
|
|
this.changeChannel(this.ChannelUtils.getChannel(result.record.parent_id), wrapper.querySelector(BDFDB.dotCN.quickswitchresultnote));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else if (instance.props.tag == "div" && instance.props.className.indexOf(BDFDB.disCN.autocompleterow) > -1) {
|
|
|
|
|
let channel = BDFDB.getReactValue(instance, "_reactInternalFiber.return.memoizedProps.channel");
|
|
|
|
|
if (channel) {
|
|
|
|
|
this.changeChannel(channel, wrapper.querySelector(BDFDB.dotCN.marginleft4));
|
|
|
|
|
let category = BDFDB.getReactValue(instance, "_reactInternalFiber.return.memoizedProps.category");
|
|
|
|
|
if (category) this.changeChannel(category, wrapper.querySelector(BDFDB.dotCN.autocompletedescription));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else if (instance.props.tag == "span" && instance.props.className.indexOf(BDFDB.disCN.messagespopoutchannelname) > -1) {
|
|
|
|
|
let channel = BDFDB.getReactValue(instance, "_reactInternalFiber.return.sibling.child.child.memoizedProps.channel");
|
|
|
|
|
if (channel) this.changeChannel2(channel, wrapper);
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
changeChannel (info, channelname) {
|
|
|
|
|
if (!info || !channelname || !channelname.parentElement) return;
|
|
|
|
|
if (channelname.EditChannelsChangeObserver && typeof channelname.EditChannelsChangeObserver.disconnect == "function") channelname.EditChannelsChangeObserver.disconnect();
|
|
|
|
|
let data = BDFDB.loadData(info.id, this, "channels") || {};
|
|
|
|
|
let settings = BDFDB.getAllData(this, "settings");
|
|
|
|
|
let color = this.chooseColor(channelname, data.color);
|
|
|
|
|
channelname.style.setProperty("color", color, "important");
|
|
|
|
|
BDFDB.setInnerText(channelname, data.name || info.name);
|
|
|
|
|
let iconparent = BDFDB.containsClass(channelname, BDFDB.disCN.quickswitchresultmatch) ? channelname.parentElement.parentElement : channelname.parentElement;
|
|
|
|
|
if (!BDFDB.containsClass(channelname, BDFDB.disCN.autocompletedescription)) {
|
|
|
|
|
iconparent.querySelectorAll('svg [stroke]:not([stroke="none"]').forEach(icon => {
|
|
|
|
|
if (!icon.getAttribute("oldstroke")) icon.setAttribute("oldstroke", icon.getAttribute("stroke"));
|
|
|
|
|
icon.setAttribute("stroke", color && settings.changeChannelIcon ? color : icon.getAttribute("oldstroke"), "important");
|
|
|
|
|
icon.style.setProperty("stroke", color && settings.changeChannelIcon ? color : icon.getAttribute("oldstroke"), "important");
|
|
|
|
|
});
|
|
|
|
|
iconparent.querySelectorAll('svg [fill]:not([fill="none"]').forEach(icon => {
|
|
|
|
|
if (!icon.getAttribute("oldfill")) icon.setAttribute("oldfill", icon.getAttribute("fill"));
|
|
|
|
|
icon.setAttribute("fill", color && settings.changeChannelIcon ? color : icon.getAttribute("oldfill"), "important");
|
|
|
|
|
icon.style.setProperty("fill", color && settings.changeChannelIcon ? color : icon.getAttribute("oldfill"), "important");
|
|
|
|
|
});
|
|
|
|
|
let unread = iconparent.parentElement.querySelector(BDFDB.dotCN.channelunread);
|
|
|
|
|
if (unread) unread.style.setProperty("background-color", color && settings.changeUnreadIndicator ? color : null, "important");
|
|
|
|
|
}
|
|
|
|
|
if (color) {
|
|
|
|
|
channelname.EditChannelsChangeObserver = new MutationObserver((changes, _) => {
|
|
|
|
|
changes.forEach(
|
|
|
|
|
(change, i) => {
|
|
|
|
|
if (change.type == "childList" && change.addedNodes.length && change.target.tagName && (change.target.tagName == "SVG" || change.target.querySelector("svg")) || change.type == "attributes" && change.attributeName == "class" && change.target.className.length && change.target.className.indexOf("name") > -1 || change.type == "attributes" && change.attributeName == "style" && BDFDB.containsClass(change.target, BDFDB.disCN.channelheaderchannelname)) {
|
|
|
|
|
channelname.EditChannelsChangeObserver.disconnect();
|
|
|
|
|
this.changeChannel(info, channelname);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
channelname.EditChannelsChangeObserver.observe(iconparent, {attributes:true, childList:true, subtree:true});
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
changeChannel2 (info, channelname) {
|
|
|
|
|
if (!info || !channelname || !channelname.parentElement) return;
|
|
|
|
|
if (channelname.EditChannelsChangeObserver && typeof channelname.EditChannelsChangeObserver.disconnect == "function") channelname.EditChannelsChangeObserver.disconnect();
|
|
|
|
|
let data = BDFDB.loadData(info.id, this, "channels") || {};
|
|
|
|
|
let color = this.chooseColor(channelname, data.color);
|
|
|
|
|
channelname.style.setProperty("color", color, "important");
|
|
|
|
|
BDFDB.setInnerText(channelname, "#" + (data.name || info.name));
|
|
|
|
|
if (color) {
|
|
|
|
|
channelname.EditChannelsChangeObserver = new MutationObserver((changes, _) => {
|
|
|
|
|
changes.forEach(
|
|
|
|
|
(change, i) => {
|
|
|
|
|
if (change.type == "childList" && change.addedNodes.length && change.target.tagName && (change.target.tagName == "SVG" || change.target.querySelector("svg")) || change.type == "attributes" && change.attributeName == "class" && change.target.className.length && change.target.className.indexOf("name") > -1) {
|
|
|
|
|
channelname.EditChannelsChangeObserver.disconnect();
|
|
|
|
|
this.changeChannel2(info, channelname);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
channelname.EditChannelsChangeObserver.observe(channelname.parentElement, {attributes:true, childList:true, subtree:true});
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
changeMention (info, mention, categoryinfo) {
|
|
|
|
|
if (!info || !mention || !mention.parentElement) return;
|
|
|
|
|
if (mention.EditChannelsChangeObserver && typeof mention.EditChannelsChangeObserver.disconnect == "function") mention.EditChannelsChangeObserver.disconnect();
|
|
|
|
|
mention.removeEventListener("mouseover", mention.mouseoverListenerEditChannels);
|
|
|
|
|
mention.removeEventListener("mouseout", mention.mouseoutListenerEditChannels);
|
|
|
|
|
let data = BDFDB.loadData(info.id, this, "channels") || {};
|
|
|
|
|
let color = BDFDB.colorCONVERT(data.color, "RGBCOMP");
|
|
|
|
|
BDFDB.setInnerText(mention, "#" + (data.name || info.name));
|
|
|
|
|
if (mention.EditChannelsHovered) colorHover();
|
|
|
|
|
else colorDefault();
|
|
|
|
|
mention.mouseoverListenerEditChannels = () => {
|
|
|
|
|
mention.EditChannelsHovered = true;
|
|
|
|
|
colorHover();
|
|
|
|
|
let categorydata = BDFDB.loadData(categoryinfo.id, this, "channels") || {};
|
|
|
|
|
if (categorydata.name) BDFDB.createTooltip(categorydata.name, mention, {type:"top",selector:"EditChannels-tooltip",css:`body ${BDFDB.dotCN.tooltip}:not(.EditChannels-tooltip) {display: none !important;}`});
|
|
|
|
|
};
|
|
|
|
|
mention.mouseoutListenerEditChannels = () => {
|
|
|
|
|
delete mention.EditChannelsHovered;
|
|
|
|
|
colorDefault();
|
|
|
|
|
};
|
|
|
|
|
mention.addEventListener("mouseover", mention.mouseoverListenerEditChannels);
|
|
|
|
|
mention.addEventListener("mouseout", mention.mouseoutListenerEditChannels);
|
|
|
|
|
mention.EditChannelsChangeObserver = new MutationObserver((changes, _) => {
|
|
|
|
|
mention.EditChannelsChangeObserver.disconnect();
|
|
|
|
|
this.changeMention(info, mention, categoryinfo);
|
|
|
|
|
});
|
|
|
|
|
mention.EditChannelsChangeObserver.observe(mention, {attributes:true});
|
|
|
|
|
function colorDefault() {
|
|
|
|
|
mention.style.setProperty("color", color ? "rgb(" + color[0] + "," + color[1] + "," + color[2] + ")" : null, "important");
|
|
|
|
|
mention.style.setProperty("background", color ? "rgba(" + color[0] + "," + color[1] + "," + color[2] + ",.1)" : null, "important");
|
|
|
|
|
}
|
|
|
|
|
function colorHover() {
|
|
|
|
|
mention.style.setProperty("color", color ? "#FFFFFF" : null, "important");
|
|
|
|
|
mention.style.setProperty("background", color ? "rgba(" + color[0] + "," + color[1] + "," + color[2] + ",.7)" : null, "important");
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
chooseColor (channelname, color) {
|
|
|
|
|
if (color && channelname) {
|
|
|
|
|
let classname = channelname.className ? channelname.className.toLowerCase() : "";
|
|
|
|
|
if (classname.indexOf("muted") > -1 || classname.indexOf("locked") > -1) color = BDFDB.colorCHANGE(color, -0.5);
|
|
|
|
|
else if (classname.indexOf("selected") > -1 || classname.indexOf("hovered") > -1 || classname.indexOf("unread") > -1) color = BDFDB.colorCHANGE(color, 0.5);
|
|
|
|
|
return BDFDB.colorCONVERT(color, "RGB");
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
2019-01-26 23:54:46 +01:00
|
|
|
|
return null;
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
addAutoCompleteMenu (textarea, channel) {
|
|
|
|
|
if (textarea.parentElement.querySelector(".autocompleteEditChannelsRow")) return;
|
|
|
|
|
let words = textarea.value.split(/\s/);
|
|
|
|
|
let lastword = words[words.length-1].trim();
|
|
|
|
|
if (lastword && lastword.length > 1 && lastword[0] == "#") {
|
|
|
|
|
let channels = BDFDB.loadAllData(this, "channels");
|
|
|
|
|
if (!channels) return;
|
|
|
|
|
let channelarray = [];
|
|
|
|
|
for (let id in channels) if (channels[id].name) {
|
|
|
|
|
let channel = this.ChannelUtils.getChannel(id);
|
|
|
|
|
let category = channel && channel.parent_id ? this.ChannelUtils.getChannel(channel.parent_id) : null;
|
|
|
|
|
let catdata = (category ? channels[category.id] : null) || {};
|
|
|
|
|
if (channel && channel.type == 0) channelarray.push(Object.assign({lowercasename:channels[id].name.toLowerCase(),lowercasecatname:(catdata && catdata.name ? catdata.name.toLowerCase() : null),channel,category,catdata},channels[id]));
|
|
|
|
|
}
|
|
|
|
|
channelarray = BDFDB.sortArrayByKey(channelarray.filter(n => n.lowercasename.indexOf(lastword.toLowerCase().slice(1)) != -1 || (n.lowercasecatname && n.lowercasecatname.indexOf(lastword.toLowerCase().slice(1)) != -1)), "lowercasename");
|
|
|
|
|
if (channelarray.length) {
|
|
|
|
|
let settings = BDFDB.getAllData(this, "settings");
|
|
|
|
|
let autocompletemenu = textarea.parentElement.querySelector(BDFDB.dotCNS.autocomplete + BDFDB.dotCN.autocompleteinner), amount = 15;
|
|
|
|
|
if (!autocompletemenu) {
|
|
|
|
|
autocompletemenu = BDFDB.htmlToElement(`<div class="${BDFDB.disCNS.autocomplete + BDFDB.disCN.autocomplete2} autocompleteEditChannels"><div class="${BDFDB.disCN.autocompleteinner}"><div class="${BDFDB.disCNS.autocompleterowvertical + BDFDB.disCN.autocompleterow} autocompleteEditChannelsRow"><div class="${BDFDB.disCN.autocompleteselector} autocompleteEditChannelsSelector"><div class="${BDFDB.disCNS.autocompletecontenttitle + BDFDB.disCNS.small + BDFDB.disCNS.size12 + BDFDB.disCNS.height16 + BDFDB.disCN.weightsemibold}">${BDFDB.LanguageStrings.TEXT_CHANNELS_MATCHING.replace("{{prefix}}", BDFDB.encodeToHTML(lastword))}</strong></div></div></div></div></div>`);
|
|
|
|
|
textarea.parentElement.appendChild(autocompletemenu);
|
|
|
|
|
autocompletemenu = autocompletemenu.firstElementChild;
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
|
|
|
|
else {
|
2019-01-26 23:54:46 +01:00
|
|
|
|
amount -= autocompletemenu.querySelectorAll(BDFDB.dotCN.autocompleteselectable).length;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BDFDB.addEventListener(this, autocompletemenu, "mouseenter", BDFDB.dotCN.autocompleteselectable, e => {
|
|
|
|
|
var selected = autocompletemenu.querySelectorAll(BDFDB.dotCN.autocompleteselected);
|
|
|
|
|
BDFDB.removeClass(selected, BDFDB.disCN.autocompleteselected);
|
|
|
|
|
BDFDB.addClass(selected, BDFDB.disCN.autocompleteselector);
|
|
|
|
|
BDFDB.addClass(e.currentTarget, BDFDB.disCN.autocompleteselected);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
for (let data of channelarray) {
|
|
|
|
|
if (amount-- < 1) break;
|
|
|
|
|
let color = BDFDB.colorCONVERT(data.color, "RGB");
|
|
|
|
|
let catcolor = BDFDB.colorCONVERT(data.catdata.color, "RGB");
|
|
|
|
|
let autocompleterow = BDFDB.htmlToElement(`<div class="${BDFDB.disCNS.autocompleterowvertical + BDFDB.disCN.autocompleterow} autocompleteEditChannelsRow"><div channelid="${data.channel.id}" class="${BDFDB.disCNS.autocompleteselector + BDFDB.disCN.autocompleteselectable} autocompleteEditChannelsSelector"><div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.autocompletecontent}" style="flex: 1 1 auto;"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16" class="${BDFDB.disCN.autocompleteicon}"><path class="${BDFDB.disCN.autocompleteiconforeground}" d="M2.27333333,12 L2.74666667,9.33333333 L0.08,9.33333333 L0.313333333,8 L2.98,8 L3.68666667,4 L1.02,4 L1.25333333,2.66666667 L3.92,2.66666667 L4.39333333,0 L5.72666667,0 L5.25333333,2.66666667 L9.25333333,2.66666667 L9.72666667,0 L11.06,0 L10.5866667,2.66666667 L13.2533333,2.66666667 L13.02,4 L10.3533333,4 L9.64666667,8 L12.3133333,8 L12.08,9.33333333 L9.41333333,9.33333333 L8.94,12 L7.60666667,12 L8.08,9.33333333 L4.08,9.33333333 L3.60666667,12 L2.27333333,12 L2.27333333,12 Z M5.02,4 L4.31333333,8 L8.31333333,8 L9.02,4 L5.02,4 L5.02,4 Z" transform="translate(1.333 2)" ${settings.changeChannelIcon && color ? ('fill="' + color + '" oldfill="currentColor" style="fill: ' + color + ' !important;"') : 'fill="currentColor"'}></path></svg><div class="${BDFDB.disCN.marginleft4}" changed-by-editchannels="true" style="flex: 1 1 auto;${color ? (' color: ' + color + ' !important;') : ''}">${BDFDB.encodeToHTML(data.name || data.channel.name)}</div>${data.category ? '<div class="${BDFDB.disCN.autocompletedescription}"' + (catcolor ? (' style="color: ' + catcolor + ' !important;"') : '') + '>' + BDFDB.encodeToHTML(data.catdata.name || data.category.name) + '</div>' : ''}</div></div></div>`);
|
|
|
|
|
autocompleterow.querySelector(BDFDB.dotCN.autocompleteselectable).addEventListener("click", () => {this.swapWordWithMention(textarea);});
|
|
|
|
|
autocompletemenu.appendChild(autocompleterow);
|
|
|
|
|
}
|
|
|
|
|
if (!autocompletemenu.querySelector(BDFDB.dotCN.autocompleteselected)) {
|
|
|
|
|
BDFDB.addClass(autocompletemenu.querySelector(".autocompleteEditChannelsRow " + BDFDB.dotCN.autocompleteselectable), BDFDB.disCN.autocompleteselected);
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
getNextSelection (menu, selected, forward) {
|
|
|
|
|
selected = selected ? selected : menu.querySelector(BDFDB.dotCN.autocompleteselected).parentElement;
|
|
|
|
|
let next, sibling = forward ? selected.nextElementSibling : selected.previousElementSibling;
|
|
|
|
|
if (sibling) {
|
|
|
|
|
next = sibling.querySelector(BDFDB.dotCN.autocompleteselectable);
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
2019-01-26 23:54:46 +01:00
|
|
|
|
else {
|
|
|
|
|
let items = menu.querySelectorAll(BDFDB.dotCN.autocompleteselectable);
|
|
|
|
|
next = forward ? items[0] : items[items.length-1];
|
|
|
|
|
}
|
|
|
|
|
return next ? next : this.getNextSelection(menu, sibling, forward);
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
swapWordWithMention (textarea) {
|
|
|
|
|
let selected = textarea.parentElement.querySelector(".autocompleteEditChannelsRow " + BDFDB.dotCN.autocompleteselected);
|
|
|
|
|
let channelid = selected ? selected.getAttribute("channelid") : null;
|
|
|
|
|
let words = textarea.value.split(/\s/);
|
|
|
|
|
let lastword = words[words.length-1].trim();
|
|
|
|
|
if (channelid && lastword) {
|
|
|
|
|
BDFDB.removeEles(".autocompleteEditChannels", ".autocompleteEditChannelsRow");
|
|
|
|
|
textarea.focus();
|
|
|
|
|
textarea.selectionStart = textarea.value.length - lastword.length;
|
|
|
|
|
textarea.selectionEnd = textarea.value.length;
|
|
|
|
|
document.execCommand("insertText", false, `<#${channelid}> `);
|
|
|
|
|
textarea.selectionStart = textarea.value.length;
|
|
|
|
|
textarea.selectionEnd = textarea.value.length;
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2018-10-11 10:21:26 +02:00
|
|
|
|
getSettingsPanel () {
|
2019-01-26 23:54:46 +01:00
|
|
|
|
if (!global.BDFDB || typeof BDFDB != "object" || !BDFDB.loaded || !this.started) return;
|
2018-10-11 10:21:26 +02:00
|
|
|
|
var settings = BDFDB.getAllData(this, "settings");
|
2019-01-26 23:54:46 +01:00
|
|
|
|
var settingshtml = `<div class="${this.name}-settings DevilBro-settings"><div class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.size18 + BDFDB.disCNS.height24 + BDFDB.disCNS.weightnormal + BDFDB.disCN.marginbottom8}">${this.name}</div><div class="DevilBro-settings-inner">`;
|
2018-10-11 10:21:26 +02:00
|
|
|
|
for (let key in settings) {
|
2019-01-26 23:54:46 +01:00
|
|
|
|
settingshtml += `<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom8}" style="flex: 1 1 auto;"><h3 class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style="flex: 1 1 auto;">${this.defaults.settings[key].description}</h3><div class="${BDFDB.disCNS.flexchild + BDFDB.disCNS.switchenabled + BDFDB.disCNS.switch + BDFDB.disCNS.switchvalue + BDFDB.disCNS.switchsizedefault + BDFDB.disCNS.switchsize + BDFDB.disCN.switchthemedefault}" style="flex: 0 0 auto;"><input type="checkbox" value="settings ${key}" class="${BDFDB.disCNS.switchinnerenabled + BDFDB.disCN.switchinner} settings-switch"${settings[key] ? " checked" : ""}></div></div>`;
|
2018-10-11 10:21:26 +02:00
|
|
|
|
}
|
|
|
|
|
settingshtml += `<div class="${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom8}" style="flex: 0 0 auto;"><h3 class="${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style="flex: 1 1 auto;">Reset all Channels.</h3><button type="button" class="${BDFDB.disCNS.flexchild + BDFDB.disCNS.button + BDFDB.disCNS.buttonlookfilled + BDFDB.disCNS.buttoncolorred + BDFDB.disCNS.buttonsizemedium + BDFDB.disCN.buttongrow} reset-button" style="flex: 0 0 auto;"><div class="${BDFDB.disCN.buttoncontents}">Reset</div></button></div>`;
|
2019-01-26 23:54:46 +01:00
|
|
|
|
settingshtml += `</div></div>`;
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
let settingspanel = BDFDB.htmlToElement(settingshtml);
|
2018-10-11 10:21:26 +02:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
BDFDB.initElements(settingspanel, this);
|
|
|
|
|
|
|
|
|
|
BDFDB.addEventListener(this, settingspanel, "click", ".reset-button", () => {
|
|
|
|
|
BDFDB.openConfirmModal(this, "Are you sure you want to reset all channels?", () => {
|
|
|
|
|
BDFDB.removeAllData(this, "channels");
|
|
|
|
|
BDFDB.WebModules.forceAllUpdates(this);
|
|
|
|
|
});
|
|
|
|
|
});
|
2018-10-11 10:21:26 +02:00
|
|
|
|
return settingspanel;
|
|
|
|
|
}
|
2019-01-26 22:45:19 +01:00
|
|
|
|
|
2019-01-26 23:54:46 +01:00
|
|
|
|
onSettingsClosed () {
|
|
|
|
|
if (this.SettingsUpdated) {
|
|
|
|
|
delete this.SettingsUpdated;
|
|
|
|
|
BDFDB.WebModules.forceAllUpdates(this);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-11 10:21:26 +02:00
|
|
|
|
setLabelsByLanguage () {
|
|
|
|
|
switch (BDFDB.getDiscordLanguage().id) {
|
|
|
|
|
case "hr": //croatian
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Postavke lokalnih kanala",
|
|
|
|
|
submenu_channelsettings_text: "Promijeni postavke",
|
|
|
|
|
submenu_resetsettings_text: "Vraćanje kanala",
|
|
|
|
|
modal_header_text: "Postavke lokalnih kanala",
|
|
|
|
|
modal_channelname_text: "Naziv lokalnog kanala",
|
|
|
|
|
modal_colorpicker1_text: "Boja lokalnog kanala",
|
|
|
|
|
btn_cancel_text: "Prekid",
|
|
|
|
|
btn_save_text: "Uštedjeti"
|
|
|
|
|
};
|
|
|
|
|
case "da": //danish
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Lokal kanalindstillinger",
|
|
|
|
|
submenu_channelsettings_text: "Skift indstillinger",
|
|
|
|
|
submenu_resetsettings_text: "Nulstil kanal",
|
|
|
|
|
modal_header_text: "Lokal kanalindstillinger",
|
|
|
|
|
modal_channelname_text: "Lokalt kanalnavn",
|
|
|
|
|
modal_colorpicker1_text: "Lokal kanalfarve",
|
|
|
|
|
btn_cancel_text: "Afbryde",
|
|
|
|
|
btn_save_text: "Spare"
|
|
|
|
|
};
|
|
|
|
|
case "de": //german
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Lokale Kanaleinstellungen",
|
|
|
|
|
submenu_channelsettings_text: "Einstellungen ändern",
|
|
|
|
|
submenu_resetsettings_text: "Kanal zurücksetzen",
|
|
|
|
|
modal_header_text: "Lokale Kanaleinstellungen",
|
|
|
|
|
modal_channelname_text: "Lokaler Kanalname",
|
|
|
|
|
modal_colorpicker1_text: "Lokale Kanalfarbe",
|
|
|
|
|
btn_cancel_text: "Abbrechen",
|
|
|
|
|
btn_save_text: "Speichern"
|
|
|
|
|
};
|
|
|
|
|
case "es": //spanish
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Ajustes local de canal",
|
|
|
|
|
submenu_channelsettings_text: "Cambiar ajustes",
|
|
|
|
|
submenu_resetsettings_text: "Restablecer canal",
|
|
|
|
|
modal_header_text: "Ajustes local de canal",
|
|
|
|
|
modal_channelname_text: "Nombre local del canal",
|
|
|
|
|
modal_colorpicker1_text: "Color local del canal",
|
|
|
|
|
btn_cancel_text: "Cancelar",
|
|
|
|
|
btn_save_text: "Guardar"
|
|
|
|
|
};
|
|
|
|
|
case "fr": //french
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Paramètres locale du canal",
|
|
|
|
|
submenu_channelsettings_text: "Modifier les paramètres",
|
|
|
|
|
submenu_resetsettings_text: "Réinitialiser le canal",
|
|
|
|
|
modal_header_text: "Paramètres locale du canal",
|
|
|
|
|
modal_channelname_text: "Nom local du canal",
|
|
|
|
|
modal_colorpicker1_text: "Couleur locale de la chaîne",
|
|
|
|
|
btn_cancel_text: "Abandonner",
|
|
|
|
|
btn_save_text: "Enregistrer"
|
|
|
|
|
};
|
|
|
|
|
case "it": //italian
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Impostazioni locale canale",
|
|
|
|
|
submenu_channelsettings_text: "Cambia impostazioni",
|
|
|
|
|
submenu_resetsettings_text: "Ripristina canale",
|
|
|
|
|
modal_header_text: "Impostazioni locale canale",
|
|
|
|
|
modal_channelname_text: "Nome locale canale",
|
|
|
|
|
modal_colorpicker1_text: "Colore locale canale",
|
|
|
|
|
btn_cancel_text: "Cancellare",
|
|
|
|
|
btn_save_text: "Salvare"
|
|
|
|
|
};
|
|
|
|
|
case "nl": //dutch
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Lokale kanaalinstellingen",
|
|
|
|
|
submenu_channelsettings_text: "Verandere instellingen",
|
|
|
|
|
submenu_resetsettings_text: "Reset kanaal",
|
|
|
|
|
modal_header_text: "Lokale kanaalinstellingen",
|
|
|
|
|
modal_channelname_text: "Lokale kanaalnaam",
|
|
|
|
|
modal_colorpicker1_text: "Lokale kanaalkleur",
|
|
|
|
|
btn_cancel_text: "Afbreken",
|
|
|
|
|
btn_save_text: "Opslaan"
|
|
|
|
|
};
|
|
|
|
|
case "no": //norwegian
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Lokal kanalinnstillinger",
|
|
|
|
|
submenu_channelsettings_text: "Endre innstillinger",
|
|
|
|
|
submenu_resetsettings_text: "Tilbakestill kanal",
|
|
|
|
|
modal_header_text: "Lokal kanalinnstillinger",
|
|
|
|
|
modal_channelname_text: "Lokalt kanalnavn",
|
|
|
|
|
modal_colorpicker1_text: "Lokal kanalfarge",
|
|
|
|
|
btn_cancel_text: "Avbryte",
|
|
|
|
|
btn_save_text: "Lagre"
|
|
|
|
|
};
|
|
|
|
|
case "pl": //polish
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Lokalne ustawienia kanału",
|
|
|
|
|
submenu_channelsettings_text: "Zmień ustawienia",
|
|
|
|
|
submenu_resetsettings_text: "Resetuj ustawienia",
|
|
|
|
|
modal_header_text: "Lokalne ustawienia kanału",
|
|
|
|
|
modal_channelname_text: "Lokalna nazwa kanału",
|
|
|
|
|
modal_colorpicker1_text: "Lokalny kolor kanału",
|
|
|
|
|
btn_cancel_text: "Anuluj",
|
|
|
|
|
btn_save_text: "Zapisz"
|
|
|
|
|
};
|
|
|
|
|
case "pt-BR": //portuguese (brazil)
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Configurações local do canal",
|
|
|
|
|
submenu_channelsettings_text: "Mudar configurações",
|
|
|
|
|
submenu_resetsettings_text: "Redefinir canal",
|
|
|
|
|
modal_header_text: "Configurações local do canal",
|
|
|
|
|
modal_channelname_text: "Nome local do canal",
|
|
|
|
|
modal_colorpicker1_text: "Cor local do canal",
|
|
|
|
|
btn_cancel_text: "Cancelar",
|
|
|
|
|
btn_save_text: "Salvar"
|
|
|
|
|
};
|
|
|
|
|
case "fi": //finnish
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Paikallinen kanavan asetukset",
|
|
|
|
|
submenu_channelsettings_text: "Vaihda asetuksia",
|
|
|
|
|
submenu_resetsettings_text: "Nollaa kanava",
|
|
|
|
|
modal_header_text: "Paikallinen kanavan asetukset",
|
|
|
|
|
modal_channelname_text: "Paikallinen kanavanimi",
|
|
|
|
|
modal_colorpicker1_text: "Paikallinen kanavanväri",
|
|
|
|
|
btn_cancel_text: "Peruuttaa",
|
|
|
|
|
btn_save_text: "Tallentaa"
|
|
|
|
|
};
|
|
|
|
|
case "sv": //swedish
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Lokal kanalinställningar",
|
|
|
|
|
submenu_channelsettings_text: "Ändra inställningar",
|
|
|
|
|
submenu_resetsettings_text: "Återställ kanal",
|
|
|
|
|
modal_header_text: "Lokal kanalinställningar",
|
|
|
|
|
modal_channelname_text: "Lokalt kanalnamn",
|
|
|
|
|
modal_colorpicker1_text: "Lokal kanalfärg",
|
|
|
|
|
btn_cancel_text: "Avbryta",
|
|
|
|
|
btn_save_text: "Spara"
|
|
|
|
|
};
|
|
|
|
|
case "tr": //turkish
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Yerel Kanal Ayarları",
|
|
|
|
|
submenu_channelsettings_text: "Ayarları Değiştir",
|
|
|
|
|
submenu_resetsettings_text: "Kanal Sıfırla",
|
|
|
|
|
modal_header_text: "Yerel Kanal Ayarları",
|
|
|
|
|
modal_channelname_text: "Yerel Kanal Adı",
|
|
|
|
|
modal_colorpicker1_text: "Yerel Kanal Rengi",
|
|
|
|
|
btn_cancel_text: "Iptal",
|
|
|
|
|
btn_save_text: "Kayıt"
|
|
|
|
|
};
|
|
|
|
|
case "cs": //czech
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Místní nastavení kanálu",
|
|
|
|
|
submenu_channelsettings_text: "Změnit nastavení",
|
|
|
|
|
submenu_resetsettings_text: "Obnovit kanál",
|
|
|
|
|
modal_header_text: "Místní nastavení kanálu",
|
|
|
|
|
modal_channelname_text: "Místní název kanálu",
|
|
|
|
|
modal_colorpicker1_text: "Místní barvy kanálu",
|
|
|
|
|
btn_cancel_text: "Zrušení",
|
|
|
|
|
btn_save_text: "Uložit"
|
|
|
|
|
};
|
|
|
|
|
case "bg": //bulgarian
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Настройки за локални канали",
|
|
|
|
|
submenu_channelsettings_text: "Промяна на настройките",
|
|
|
|
|
submenu_resetsettings_text: "Възстановяване на канал",
|
|
|
|
|
modal_header_text: "Настройки за локални канали",
|
|
|
|
|
modal_channelname_text: "Локално име на канал",
|
|
|
|
|
modal_colorpicker1_text: "Локален цветен канал",
|
|
|
|
|
btn_cancel_text: "Зъбести",
|
|
|
|
|
btn_save_text: "Cпасяване"
|
|
|
|
|
};
|
|
|
|
|
case "ru": //russian
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Настройки локального канала",
|
|
|
|
|
submenu_channelsettings_text: "Изменить настройки",
|
|
|
|
|
submenu_resetsettings_text: "Сбросить канал",
|
|
|
|
|
modal_header_text: "Настройки локального канала",
|
|
|
|
|
modal_channelname_text: "Имя локального канала",
|
|
|
|
|
modal_colorpicker1_text: "Цвет локального канала",
|
|
|
|
|
btn_cancel_text: "Отмена",
|
|
|
|
|
btn_save_text: "Cпасти"
|
|
|
|
|
};
|
|
|
|
|
case "uk": //ukrainian
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Налаштування локального каналу",
|
|
|
|
|
submenu_channelsettings_text: "Змінити налаштування",
|
|
|
|
|
submenu_resetsettings_text: "Скидання каналу",
|
|
|
|
|
modal_header_text: "Налаштування локального каналу",
|
|
|
|
|
modal_channelname_text: "Локальне ім'я каналу",
|
|
|
|
|
modal_colorpicker1_text: "Колір місцевого каналу",
|
|
|
|
|
btn_cancel_text: "Скасувати",
|
|
|
|
|
btn_save_text: "Зберегти"
|
|
|
|
|
};
|
|
|
|
|
case "ja": //japanese
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "ローカルチャネル設定",
|
|
|
|
|
submenu_channelsettings_text: "設定を変更する",
|
|
|
|
|
submenu_resetsettings_text: "チャネルをリセットする",
|
|
|
|
|
modal_header_text: "ローカルチャネル設定",
|
|
|
|
|
modal_channelname_text: "ローカルチャネル名",
|
|
|
|
|
modal_colorpicker1_text: "ローカルチャネルの色",
|
|
|
|
|
btn_cancel_text: "キャンセル",
|
|
|
|
|
btn_save_text: "セーブ"
|
|
|
|
|
};
|
|
|
|
|
case "zh-TW": //chinese (traditional)
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "本地頻道設置",
|
|
|
|
|
submenu_channelsettings_text: "更改設置",
|
|
|
|
|
submenu_resetsettings_text: "重置通道",
|
|
|
|
|
modal_header_text: "本地頻道設置",
|
|
|
|
|
modal_channelname_text: "本地頻道名稱",
|
|
|
|
|
modal_colorpicker1_text: "本地頻道顏色",
|
|
|
|
|
btn_cancel_text: "取消",
|
|
|
|
|
btn_save_text: "保存"
|
|
|
|
|
};
|
|
|
|
|
case "ko": //korean
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "로컬 채널 설정",
|
|
|
|
|
submenu_channelsettings_text: "설정 변경",
|
|
|
|
|
submenu_resetsettings_text: "채널 재설정",
|
|
|
|
|
modal_header_text: "로컬 채널 설정",
|
|
|
|
|
modal_channelname_text: "로컬 채널 이름",
|
|
|
|
|
modal_colorpicker1_text: "지역 채널 색깔",
|
|
|
|
|
btn_cancel_text: "취소",
|
|
|
|
|
btn_save_text: "저장"
|
|
|
|
|
};
|
|
|
|
|
default: //default: english
|
|
|
|
|
return {
|
|
|
|
|
context_localchannelsettings_text: "Local Channelsettings",
|
|
|
|
|
submenu_channelsettings_text: "Change Settings",
|
|
|
|
|
submenu_resetsettings_text: "Reset Channel",
|
|
|
|
|
modal_header_text: "Local Channelsettings",
|
|
|
|
|
modal_channelname_text: "Local Channelname",
|
|
|
|
|
modal_colorpicker1_text: "Local Channelcolor",
|
|
|
|
|
btn_cancel_text: "Cancel",
|
|
|
|
|
btn_save_text: "Save"
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|