This commit is contained in:
Mirco Wittrien 2019-10-14 12:31:52 +02:00
parent a1d5015f98
commit 51f24b3caf
3 changed files with 164 additions and 45 deletions

File diff suppressed because one or more lines are too long

View File

@ -1040,10 +1040,6 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
return parseInt(document.firstElementChild.style.fontSize.replace('%', '')); return parseInt(document.firstElementChild.style.fontSize.replace('%', ''));
}; };
BDFDB.isColorBlindModeEnabled = function () {
return true;
};
BDFDB.getReactInstance = function (node) { BDFDB.getReactInstance = function (node) {
if (!BDFDB.isObject(node)) return null; if (!BDFDB.isObject(node)) return null;
return node[Object.keys(node).find(key => key.startsWith('__reactInternalInstance'))]; return node[Object.keys(node).find(key => key.startsWith('__reactInternalInstance'))];
@ -2483,7 +2479,7 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
case 'HSLCOMP': case 'HSLCOMP':
var a = rgbcomp.length == 4 ? processA(rgbcomp.pop()) : null; var a = rgbcomp.length == 4 ? processA(rgbcomp.pop()) : null;
var hslcomp = processHSL(BDFDB.colorCONVERT(rgbcomp, 'HSL').replace(/\s/g, '').split(',')); var hslcomp = processHSL(BDFDB.colorCONVERT(rgbcomp, 'HSL').replace(/\s/g, '').split(','));
return a ? hslcomp.concat(a) : hslcomp; return a != null ? hslcomp.concat(a) : hslcomp;
case 'HSL': case 'HSL':
var r = processC(rgbcomp[0]), g = processC(rgbcomp[1]), b = processC(rgbcomp[2]); var r = processC(rgbcomp[0]), g = processC(rgbcomp[1]), b = processC(rgbcomp[2]);
var max = Math.max(r, g, b), min = Math.min(r, g, b), dif = max - min, h, l = max === 0 ? 0 : dif / max, s = max / 255; var max = Math.max(r, g, b), min = Math.min(r, g, b), dif = max - min, h, l = max === 0 ? 0 : dif / max, s = max / 255;
@ -2500,7 +2496,7 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
case 'HEX': case 'HEX':
return ('#' + (0x1000000 + (rgbcomp[2] | rgbcomp[1] << 8 | rgbcomp[0] << 16)).toString(16).slice(1)).toUpperCase(); return ('#' + (0x1000000 + (rgbcomp[2] | rgbcomp[1] << 8 | rgbcomp[0] << 16)).toString(16).slice(1)).toUpperCase();
case 'HEXA': case 'HEXA':
return ('#' + (0x1000000 + (rgbcomp[2] | rgbcomp[1] << 8 | rgbcomp[0] << 16)).toString(16).slice(1) + Math.round(BDFDB.mapRange([0, 100], [0, 255], processA(rgbcomp[3]) * 100)).toString(16)).toUpperCase(); return ('#' + (0x1000000 + (rgbcomp[2] | rgbcomp[1] << 8 | rgbcomp[0] << 16)).toString(16).slice(1) + (0x100 + Math.round(BDFDB.mapRange([0, 100], [0, 255], processA(rgbcomp[3]) * 100))).toString(16).slice(1)).toUpperCase();
case 'INT': case 'INT':
return processINT(rgbcomp[2] | rgbcomp[1] << 8 | rgbcomp[0] << 16); return processINT(rgbcomp[2] | rgbcomp[1] << 8 | rgbcomp[0] << 16);
default: default:
@ -2593,10 +2589,10 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
return null; return null;
}; };
BDFDB.colorISBRIGHT = function (color, value) { BDFDB.colorISBRIGHT = function (color, compare = 160) {
color = BDFDB.colorCONVERT(color, 'INT'); color = BDFDB.colorCONVERT(color, 'RGBCOMP');
if (color == null) return false; if (!color) return false;
return LibraryModules.ColorUtils.getDarkness(color) < (typeof value == 'number' ? value : 0.3); return parseInt(compare) < Math.sqrt(0.299 * color[0]**2 + 0.587 * color[1]**2 + 0.144 * color[2]**2);
}; };
BDFDB.colorTYPE = function (color) { BDFDB.colorTYPE = function (color) {
@ -3643,12 +3639,12 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
var setSwatch = (swatch, color, selected) => { var setSwatch = (swatch, color, selected) => {
if (!swatch) return; if (!swatch) return;
else if (selected) { else if (selected) {
BDFDB.addClass(swatch, 'selected'); BDFDB.addClass(swatch, BDFDB.disCN.colorpickerswatchselected);
var iscustom = BDFDB.containsClass(swatch, BDFDB.disCN.colorpickerswatchcustom); var iscustom = BDFDB.containsClass(swatch, BDFDB.disCN.colorpickerswatchcustom);
var isgradient = color && BDFDB.isObject(color); var isgradient = color && BDFDB.isObject(color);
var selectedcolor = !isgradient ? BDFDB.colorCONVERT(color, 'RGBA') : BDFDB.colorGRADIENT(color); var selectedcolor = BDFDB.isObject(color) ? BDFDB.colorGRADIENT(color) : BDFDB.colorCONVERT(color, 'RGBA');
var bright = selectedcolor && !isgradient ? BDFDB.colorISBRIGHT(selectedcolor) : false; var bright = selectedcolor && !isgradient ? BDFDB.colorISBRIGHT(selectedcolor) : false;
if (!swatch.querySelector(".swatch-checkmark")) swatch.appendChild(BDFDB.htmlToElement(`<svg class="swatch-checkmark" name="Checkmark" aria-hidden="false" width="${iscustom ? 32 : 16}" height="${iscustom ? 24 : 16}" viewBox="0 0 18 18" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><polyline stroke="${bright ? '#000000' : '#ffffff'}" stroke-width="2" points="3.5 9.5 7 13 15 5"></polyline></g></svg>`)); if (!swatch.querySelector(`svg[name="Checkmark"]`)) swatch.appendChild(BDFDB.htmlToElement(`<svg class="swatch-checkmark" name="Checkmark" aria-hidden="false" width="${iscustom ? 32 : 16}" height="${iscustom ? 24 : 16}" viewBox="0 0 18 18" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><polyline stroke="${bright ? '#000000' : '#ffffff'}" stroke-width="2" points="3.5 9.5 7 13 15 5"></polyline></g></svg>`));
if (iscustom) { if (iscustom) {
BDFDB.removeClass(swatch, BDFDB.disCN.colorpickerswatchnocolor); BDFDB.removeClass(swatch, BDFDB.disCN.colorpickerswatchnocolor);
swatch.querySelector(BDFDB.dotCN.colorpickerswatchdropperfg).setAttribute('fill', bright ? '#000000' : '#ffffff'); swatch.querySelector(BDFDB.dotCN.colorpickerswatchdropperfg).setAttribute('fill', bright ? '#000000' : '#ffffff');
@ -3674,9 +3670,9 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
BDFDB.setColorSwatches = function (container, currentcolor) { BDFDB.setColorSwatches = function (container, currentcolor) {
if (!Node.prototype.isPrototypeOf(container)) return; if (!Node.prototype.isPrototypeOf(container)) return;
var swatches = container.querySelector('.swatches:not([swatchnr])'); var swatches = container.querySelector(`${BDFDB.dotCN.colorpickerswatches}:not([swatchnr])`);
if (!swatches) return; if (!swatches) return;
swatches.setAttribute('swatchnr', parseInt(container.querySelectorAll('.swatches[swatchnr]').length + 1)); swatches.setAttribute('swatchnr', parseInt(container.querySelectorAll(`${BDFDB.dotCN.colorpickerswatches}[swatchnr]`).length + 1));
var colorlist = [null, 'rgba(82,233,30,1)', 'rgba(46,204,113,1)', 'rgba(26,188,156,1)', 'rgba(52,152,219,1)', 'rgba(52,84,219,1)', 'rgba(134,30,233,1)', 'rgba(155,89,182,1)', 'rgba(233,30,99,1)', 'rgba(233,65,30,1)', 'rgba(231,76,60,1)', 'rgba(230,126,34,1)', 'rgba(241,196,15,1)', 'rgba(199,204,205,1)', 'rgba(112,128,136,1)', 'rgba(99,99,99,1)', 'rgba(255,255,255,1)', 'rgba(59,173,20,1)', 'rgba(31,139,76,1)', 'rgba(17,128,106,1)', 'rgba(32,102,148,1)', 'rgba(32,57,148,1)', 'rgba(109,20,173,1)', 'rgba(113,54,138,1)', 'rgba(173,20,87,1)', 'rgba(173,32,20,1)', 'rgba(153,45,34,1)', 'rgba(168,67,0,1)', 'rgba(194,124,14,1)', 'rgba(151,156,159,1)', 'rgba(93,104,109,1)', 'rgba(44,44,44,1)']; var colorlist = [null, 'rgba(82,233,30,1)', 'rgba(46,204,113,1)', 'rgba(26,188,156,1)', 'rgba(52,152,219,1)', 'rgba(52,84,219,1)', 'rgba(134,30,233,1)', 'rgba(155,89,182,1)', 'rgba(233,30,99,1)', 'rgba(233,65,30,1)', 'rgba(231,76,60,1)', 'rgba(230,126,34,1)', 'rgba(241,196,15,1)', 'rgba(199,204,205,1)', 'rgba(112,128,136,1)', 'rgba(99,99,99,1)', 'rgba(255,255,255,1)', 'rgba(59,173,20,1)', 'rgba(31,139,76,1)', 'rgba(17,128,106,1)', 'rgba(32,102,148,1)', 'rgba(32,57,148,1)', 'rgba(109,20,173,1)', 'rgba(113,54,138,1)', 'rgba(173,20,87,1)', 'rgba(173,32,20,1)', 'rgba(153,45,34,1)', 'rgba(168,67,0,1)', 'rgba(194,124,14,1)', 'rgba(151,156,159,1)', 'rgba(93,104,109,1)', 'rgba(44,44,44,1)'];
var colorrows = [colorlist.slice(0, parseInt(colorlist.length/2)), colorlist.slice(parseInt(colorlist.length/2))]; var colorrows = [colorlist.slice(0, parseInt(colorlist.length/2)), colorlist.slice(parseInt(colorlist.length/2))];
@ -3695,7 +3691,7 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
BDFDB.openColorPicker(swatches, e.currentTarget, e.currentTarget.gradient || e.currentTarget.style.getPropertyValue("background-color")); BDFDB.openColorPicker(swatches, e.currentTarget, e.currentTarget.gradient || e.currentTarget.style.getPropertyValue("background-color"));
} }
else { else {
setSwatch(swatches.querySelector(BDFDB.dotCN.colorpickerswatch + ".selected"), null, false); setSwatch(swatches.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchselected), null, false);
setSwatch(e.currentTarget, e.currentTarget.style.getPropertyValue('background-color'), true); setSwatch(e.currentTarget, e.currentTarget.style.getPropertyValue('background-color'), true);
} }
}); });
@ -3710,7 +3706,7 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
BDFDB.getSwatchColor = function (container, nr) { BDFDB.getSwatchColor = function (container, nr) {
if (!Node.prototype.isPrototypeOf(container)) return; if (!Node.prototype.isPrototypeOf(container)) return;
var swatch = container.querySelector(`.swatches[swatchnr="${nr}"] ${BDFDB.dotCN.colorpickerswatch}.selected`); var swatch = container.querySelector(`${BDFDB.dotCN.colorpickerswatches}[swatchnr="${nr}"] ${BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchselected}`);
return swatch ? swatch.gradient || BDFDB.colorCONVERT(swatch.style.getPropertyValue('background-color'), 'RGBCOMP') : null; return swatch ? swatch.gradient || BDFDB.colorCONVERT(swatch.style.getPropertyValue('background-color'), 'RGBCOMP') : null;
}; };
@ -3725,7 +3721,8 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
var hexformat = options.alpha ? 'HEXA' : 'HEX'; var hexformat = options.alpha ? 'HEXA' : 'HEX';
var hexregex = options.alpha ? /^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i : /^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i; var hexregex = options.alpha ? /^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i : /^#([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i;
var isswatches = BDFDB.containsClass(container, 'swatches'); var isreact = BDFDB.isObject(container) && !!container._reactInternalFiber;
var isswatches = !isreact || BDFDB.containsClass(container, 'swatches');
var isgradient = color && BDFDB.isObject(color); var isgradient = color && BDFDB.isObject(color);
var selectedcolor = BDFDB.colorCONVERT(isgradient ? color[Object.keys(color)[0]] : color, hexformat) || (options.alpha ? '#000000FF' : '#000000'); var selectedcolor = BDFDB.colorCONVERT(isgradient ? color[Object.keys(color)[0]] : color, hexformat) || (options.alpha ? '#000000FF' : '#000000');
var [h, s, l] = BDFDB.colorCONVERT(selectedcolor, 'HSLCOMP'); var [h, s, l] = BDFDB.colorCONVERT(selectedcolor, 'HSLCOMP');
@ -3935,20 +3932,28 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
alphacursor.style.setProperty('left', (a * 100) + '%', 'important'); alphacursor.style.setProperty('left', (a * 100) + '%', 'important');
var hex = BDFDB.colorCONVERT([h, s, l, a], hexformat); var hex = BDFDB.colorCONVERT([h, s, l, a], hexformat);
var rgb = BDFDB.colorCONVERT(hex, 'RGBA'); var rgb = BDFDB.colorCONVERT(hex, 'RGBA');
if (isswatches) { if (isreact) {
if (isgradient) {
gradientpane.querySelector('.gradient-cursor.selected').firstElementChild.style.setProperty('background-color', rgb);
updateGradient();
}
else container.setState({
selectedColor: rgb,
customColor: rgb
});
}
else if (isswatches) {
setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + '.selected'), null, false); setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + '.selected'), null, false);
if (isgradient) { if (isgradient) {
gradientpane.querySelector('.gradient-cursor.selected').firstElementChild.style.setProperty('background-color', rgb); gradientpane.querySelector('.gradient-cursor.selected').firstElementChild.style.setProperty('background-color', rgb);
updateGradient(); updateGradient();
} }
else { else setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatch), rgb, true);
setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatch), rgb, true);
}
} }
else { else {
let input = container.querySelector(BDFDB.dotCN.input); let input = container.querySelector(BDFDB.dotCN.input);
if (input) input.value = options.comp ? BDFDB.colorCONVERT(hex, 'RGBCOMP').join(',') : rgb; if (input) input.value = options.comp ? BDFDB.colorCONVERT(hex, 'RGBCOMP').join(',') : rgb;
let swatch = container.querySelector('.single-swatch'); let swatch = container.querySelector(BDFDB.dotCN.colorpickerswatchsingle);
if (swatch) swatch.style.setProperty('background-color', rgb, 'important'); if (swatch) swatch.style.setProperty('background-color', rgb, 'important');
} }
if (setinput) hexinput.value = hex; if (setinput) hexinput.value = hex;
@ -3959,7 +3964,11 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
var gradient = {}; var gradient = {};
for (let cursor of gradientpane.querySelectorAll(".gradient-cursor")) gradient[parseFloat(cursor.style.getPropertyValue("left"))/100] = cursor.firstElementChild.style.getPropertyValue("background-color"); for (let cursor of gradientpane.querySelectorAll(".gradient-cursor")) gradient[parseFloat(cursor.style.getPropertyValue("left"))/100] = cursor.firstElementChild.style.getPropertyValue("background-color");
gradientpane.style.setProperty("background-image", BDFDB.colorGRADIENT(gradient)); gradientpane.style.setProperty("background-image", BDFDB.colorGRADIENT(gradient));
setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatch), gradient, true); if (isreact) container.setState({
selectedColor: gradient,
customColor: gradient
});
else setSwatch(container.querySelector(BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatch), gradient, true);
} }
}; };
@ -4017,6 +4026,10 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
DiscordClassModules.BDFDB = { DiscordClassModules.BDFDB = {
BDFDBundefined: 'BDFDB_undefined', BDFDBundefined: 'BDFDB_undefined',
cardInner: 'card-inner', cardInner: 'card-inner',
colorPickerSwatches: 'swatches',
colorPickerSwatchesDisabled: 'disabled',
colorPickerSwatchSingle: 'single-swatch',
colorPickerSwatchSelected: 'selected',
overflowEllipsis: 'overflowellipsis' overflowEllipsis: 'overflowellipsis'
}; };
DiscordClassModules.BDrepo = { DiscordClassModules.BDrepo = {
@ -4541,12 +4554,16 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
colorpickerrow: ['ColorPicker', 'colorPickerRow'], colorpickerrow: ['ColorPicker', 'colorPickerRow'],
colorpickersaturation: ['ColorPickerInner', 'saturation'], colorpickersaturation: ['ColorPickerInner', 'saturation'],
colorpickerswatch: ['ColorPicker', 'colorPickerSwatch'], colorpickerswatch: ['ColorPicker', 'colorPickerSwatch'],
colorpickerswatches: ['BDFDB', 'colorPickerSwatches'],
colorpickerswatchesdisabled: ['BDFDB', 'colorPickerSwatchesDisabled'],
colorpickerswatchcustom: ['ColorPicker', 'custom'], colorpickerswatchcustom: ['ColorPicker', 'custom'],
colorpickerswatchdefault: ['ColorPicker', 'default'], colorpickerswatchdefault: ['ColorPicker', 'default'],
colorpickerswatchdisabled: ['ColorPicker', 'disabled'], colorpickerswatchdisabled: ['ColorPicker', 'disabled'],
colorpickerswatchdropper: ['ColorPicker', 'colorPickerDropper'], colorpickerswatchdropper: ['ColorPicker', 'colorPickerDropper'],
colorpickerswatchdropperfg: ['ColorPicker', 'colorPickerDropperFg'], colorpickerswatchdropperfg: ['ColorPicker', 'colorPickerDropperFg'],
colorpickerswatchnocolor: ['ColorPicker', 'noColor'], colorpickerswatchnocolor: ['ColorPicker', 'noColor'],
colorpickerswatchselected: ['BDFDB', 'colorPickerSwatchSelected'],
colorpickerswatchsingle: ['BDFDB', 'colorPickerSwatchSingle'],
colorstandard: ['TextColor', 'colorStandard'], colorstandard: ['TextColor', 'colorStandard'],
contentregion: ['SettingsWindow', 'contentRegion'], contentregion: ['SettingsWindow', 'contentRegion'],
contextmenu: ['ContextMenu', 'contextMenu'], contextmenu: ['ContextMenu', 'contextMenu'],
@ -5527,6 +5544,111 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
var LibraryComponents = {}; var LibraryComponents = {};
LibraryComponents.Button = BDFDB.WebModules.findByProperties('Colors', 'Hovers', 'Looks'); LibraryComponents.Button = BDFDB.WebModules.findByProperties('Colors', 'Hovers', 'Looks');
LibraryComponents.ColorSwatches = class ColorSwatches extends BDFDB.React.Component {
constructor(props) {
super(props);
props.selectedColor = BDFDB.isObject(props.color) ? props.color : BDFDB.colorCONVERT(props.color, 'RGBA');
props.colors = (Array.isArray(props.colors) ? props.colors : [null, 5433630, 3066993, 1752220, 3447003, 3429595, 8789737, 10181046, 15277667, 15286558, 15158332, 15105570, 15844367, 13094093, 7372936, 6513507, 16777215, 3910932, 2067276, 1146986, 2123412, 2111892, 7148717, 7419530, 11342935, 11345940, 10038562, 11027200, 12745742, 9936031, 6121581, 2894892]).map(c => BDFDB.colorCONVERT(c, 'RGBA'));
props.colorRows = props.colors.length ? [props.colors.slice(0, parseInt(props.colors.length/2)), props.colors.slice(parseInt(props.colors.length/2))] : [];
props.customColor = props.selectedColor != null ? (props.colors.indexOf(props.selectedColor) > -1 ? null : props.selectedColor) : null;
props.customSelected = !!props.customColor;
props.pickerConfig = BDFDB.isObject(props.pickerConfig) ? props.pickerConfig : {gradient: true, comp: false, alpha: true, callback: _ => {}};
this.state = props;
var swatches = this;
this.ColorSwatch = class ColorSwatch extends BDFDB.React.Component {
render() {
let usewhite = !BDFDB.colorISBRIGHT(this.props.color);
return BDFDB.React.createDiscordElement('button', {
type: 'button',
className: [BDFDB.disCN.colorpickerswatch, this.props.isDisabled ? BDFDB.disCN.colorpickerswatchdisabled : null, this.props.isSelected ? BDFDB.disCN.colorpickerswatchselected : null, this.props.isCustom ? BDFDB.disCN.colorpickerswatchcustom : null, this.props.isSingle ? BDFDB.disCN.colorpickerswatchsingle : null, this.props.color == null ? BDFDB.disCN.colorpickerswatchnocolor : null].filter(n => n).join(' '),
disabled: this.props.isDisabled,
onClick: _ => {
if (!this.props.isSelected) {
let color = this.props.isCustom && this.props.color == null ? 'rgba(0,0,0,1)' : this.props.color;
swatches.setState({
selectedColor: color,
customColor: this.props.isCustom ? color : swatches.state.customColor,
customSelected: this.props.isCustom
});
}
if (this.props.isCustom || this.props.isSingle) {
let swatch = BDFDB.React.findDOMNodeSafe(this);
if (swatch) BDFDB.openColorPicker(swatches, swatch, this.props.color, swatches.state.pickerConfig);
};
},
onMouseEnter: _ => {
let swatch = this.props.isCustom || this.props.isSingle || this.props.color == null ? BDFDB.React.findDOMNodeSafe(this) : null;
if (swatch) BDFDB.createTooltip(this.props.isCustom || this.props.isSingle ? BDFDB.LanguageStrings.CUSTOM_COLOR : BDFDB.LanguageStrings.DEFAULT, swatch, {type: 'bottom'});
},
style: Object.assign({}, this.props.style, {
background: BDFDB.isObject(this.props.color) ? BDFDB.colorGRADIENT(this.props.color) : BDFDB.colorCONVERT(this.props.color, 'RGBA')
})
}, null, [
this.props.isCustom || this.props.isSingle ? BDFDB.React.createDiscordElement(BDFDB.LibraryComponents.SvgIcon, {
className: BDFDB.disCN.colorpickerswatchdropper,
foreground: BDFDB.disCN.colorpickerswatchdropperfg,
name: BDFDB.LibraryComponents.SvgIcon.Names.DROPPER,
width: this.props.isCustom ? 14 : 10,
height: this.props.isCustom ? 14 : 10,
color: usewhite ? BDFDB.DiscordConstants.Colors.WHITE : BDFDB.DiscordConstants.Colors.BLACK
}) : null,
this.props.isSelected && !this.props.isSingle ? BDFDB.React.createDiscordElement(BDFDB.LibraryComponents.SvgIcon, {
name: BDFDB.LibraryComponents.SvgIcon.Names.CHECKMARK,
width: this.props.isCustom ? 32 : 16,
height: this.props.isCustom ? 24 : 16,
color: usewhite ? BDFDB.DiscordConstants.Colors.WHITE : BDFDB.DiscordConstants.Colors.BLACK
}) : null
]);
}
}
}
renderRow(colors) {
return BDFDB.React.createDiscordElement(BDFDB.LibraryComponents.Flex, {
className: BDFDB.disCN.colorpickerrow,
wrap: BDFDB.LibraryComponents.Flex.Wrap.WRAP
}, null, colors.map(color => {
return BDFDB.React.createDiscordElement(this.ColorSwatch, {
color: color,
isCustom: false,
isSelected: !this.state.customSelected && color === this.state.selectedColor,
isDisabled: this.state.disabled
})
}));
}
render() {
return BDFDB.React.createDiscordElement(BDFDB.LibraryComponents.Flex, {
className: [BDFDB.disCN.colorpickerswatches, this.state.disabled ? BDFDB.disCN.colorpickerswatchesdisabled : null].filter(n => n).join(' '),
}, null, [
BDFDB.React.createDiscordElement(BDFDB.LibraryComponents.Flex.Child, {
shrink: 0,
grow: 0,
className: BDFDB.disCN.marginreset,
wrap: true
}, null, [
BDFDB.React.createDiscordElement(this.ColorSwatch, {
color: this.state.customColor,
isSingle: !this.state.colors.length,
isCustom: this.state.colors.length > 0,
isSelected: this.state.customSelected,
isDisabled: this.state.disabled,
style: {
margin: 0
}
})
]),
this.state.colors.length ? BDFDB.React.createDiscordElement(BDFDB.LibraryComponents.Flex, {
direction: BDFDB.LibraryComponents.Flex.Direction.VERTICAL,
className: BDFDB.disCN.flexmarginreset,
grow: 1
}, null, [
this.renderRow(this.state.colorRows[0]),
this.renderRow(this.state.colorRows[1])
]) : null
])
}
};
LibraryComponents.ContextMenu = BDFDB.WebModules.findByName('NativeContextMenu'); LibraryComponents.ContextMenu = BDFDB.WebModules.findByName('NativeContextMenu');
LibraryComponents.ContextMenuItem = BDFDB.WebModules.findByString('{className:i.default.label}', '{className:i.default.hint}'); LibraryComponents.ContextMenuItem = BDFDB.WebModules.findByString('{className:i.default.label}', '{className:i.default.hint}');
LibraryComponents.ContextMenuItemGroup = BDFDB.WebModules.findByString('{className:i.default.itemGroup}'); LibraryComponents.ContextMenuItemGroup = BDFDB.WebModules.findByString('{className:i.default.itemGroup}');
@ -6318,8 +6440,8 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
.BDFDB-settings ${BDFDB.dotCN.checkboxcontainer}:before { .BDFDB-settings ${BDFDB.dotCN.checkboxcontainer}:before {
display: none; display: none;
} }
.BDFDB-modal .swatches.disabled, .BDFDB-modal ${BDFDB.dotCN.colorpickerswatches + BDFDB.dotCN.colorpickerswatchesdisabled},
.BDFDB-settings .swatches.disabled { .BDFDB-settings ${BDFDB.dotCN.colorpickerswatches + BDFDB.dotCN.colorpickerswatchesdisabled} {
cursor: no-drop; cursor: no-drop;
filter: grayscale(70%) brightness(50%); filter: grayscale(70%) brightness(50%);
} }
@ -6352,8 +6474,8 @@ var BDFDB = {myPlugins: BDFDB && BDFDB.myPlugins ? BDFDB.myPlugins : {}, BDv2Api
.BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault}:after { .BDFDB-settings ${BDFDB.dotCN.colorpickerswatch + BDFDB.notCN.colorpickerswatchnocolor + BDFDB.notCN.colorpickerswatchdefault}:after {
background: url('data:image/svg+xml; utf8, <svg xmlns="http://www.w3.org/2000/svg" width="8" height="8"><rect x="0" y="0" width="4" height="4" fill="black"></rect><rect x="0" y="4" width="4" height="4" fill="white"></rect><rect x="4" y="0" width="4" height="4" fill="white"></rect><rect x="4" y="4" width="4" height="4" fill="black"></rect></svg>') center repeat background: url('data:image/svg+xml; utf8, <svg xmlns="http://www.w3.org/2000/svg" width="8" height="8"><rect x="0" y="0" width="4" height="4" fill="black"></rect><rect x="0" y="4" width="4" height="4" fill="white"></rect><rect x="4" y="0" width="4" height="4" fill="white"></rect><rect x="4" y="4" width="4" height="4" fill="black"></rect></svg>') center repeat
} }
.BDFDB-modal .swatches.disabled ${BDFDB.dotCN.colorpickerswatch}, .BDFDB-modal ${BDFDB.dotCN.colorpickerswatches + BDFDB.dotCN.colorpickerswatchesdisabled} ${BDFDB.dotCN.colorpickerswatch},
.BDFDB-settings .swatches.disabled ${BDFDB.dotCN.colorpickerswatch} { .BDFDB-settings ${BDFDB.dotCN.colorpickerswatches + BDFDB.dotCN.colorpickerswatchesdisabled} ${BDFDB.dotCN.colorpickerswatch} {
cursor: no-drop; cursor: no-drop;
} }
.BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchcustom}[style*="background"], .BDFDB-modal ${BDFDB.dotCN.colorpickerswatch + BDFDB.dotCN.colorpickerswatchcustom}[style*="background"],

View File

@ -44,23 +44,21 @@ class PinDMs {
</a> </a>
</foreignObject> </foreignObject>
</svg> </svg>
<div class="${BDFDB.disCN.guildbadgewrapper}"> <div class="${BDFDB.disCN.guildupperbadge} pin-badge" style="opacity: 1; transform: translate(0px, 0px);">
<div class="${BDFDB.disCN.guildupperbadge} pin-badge" style="opacity: 1; transform: translate(0px, 0px);"> <div class="${BDFDB.disCNS.guildbadgeiconbadge + BDFDB.disCN.guildbadgeiconbadge2}" style="width: 16px; padding-right: 1px;">
<div class="${BDFDB.disCNS.guildbadgeiconbadge + BDFDB.disCN.guildbadgeiconbadge2}" style="width: 16px; padding-right: 1px;"> <svg class="${BDFDB.disCN.guildbadgeicon}" name="Nova_Pin" width="24" height="24" viewBox="0 0 520 520">
<svg class="${BDFDB.disCN.guildbadgeicon}" name="Nova_Pin" width="24" height="24" viewBox="0 0 520 520"> <g fill="white">
<g fill="white"> <path d="M291.31, 402.761L109.241, 220.693C79.073, 190.525, 30.166, 190.526, 0, 220.692l291.31, 291.31C321.474, 481.835, 321.476, 432.927, 291.31, 402.761z"></path>
<path d="M291.31, 402.761L109.241, 220.693C79.073, 190.525, 30.166, 190.526, 0, 220.692l291.31, 291.31C321.474, 481.835, 321.476, 432.927, 291.31, 402.761z"></path> <polygon points="273.104, 111.449 154.758, 211.589 300.412, 357.242 400.55, 238.898"></polygon>
<polygon points="273.104, 111.449 154.758, 211.589 300.412, 357.242 400.55, 238.898"></polygon> <path d="M500.688, 175.174L336.827, 11.313c-15.085-15.085-39.539-15.083-54.621, 0c-15.082, 15.082-15.082, 39.538, 0, 54.62 l163.861, 163.861c15.083, 15.085, 39.539, 15.085, 54.621, 0.001C515.773, 214.712, 515.773, 190.257, 500.688, 175.174z"></path>
<path d="M500.688, 175.174L336.827, 11.313c-15.085-15.085-39.539-15.083-54.621, 0c-15.082, 15.082-15.082, 39.538, 0, 54.62 l163.861, 163.861c15.083, 15.085, 39.539, 15.085, 54.621, 0.001C515.773, 214.712, 515.773, 190.257, 500.688, 175.174z"></path> <polygon points="91.032, 366.346 0, 512 145.655, 420.967"></polygon>
<polygon points="91.032, 366.346 0, 512 145.655, 420.967"></polygon> </g>
</g> </svg>
</svg>
</div>
</div>
<div class="${BDFDB.disCN.guildlowerbadge}" style="opacity: 1; transform: translate(0px, 0px); display: none;">
<div class="${BDFDB.disCN.guildbadgenumberbadge}" style="background-color: rgb(240, 71, 71); width: 16px; padding-right: 1px;">0</div>
</div> </div>
</div> </div>
<div class="${BDFDB.disCN.guildlowerbadge}" style="opacity: 1; transform: translate(0px, 0px); display: none;">
<div class="${BDFDB.disCN.guildbadgenumberbadge}" style="background-color: rgb(240, 71, 71); width: 16px; padding-right: 1px;">0</div>
</div>
</div> </div>
</div> </div>
</div> </div>
@ -82,7 +80,6 @@ class PinDMs {
<div class="${BDFDB.disCN.guildplaceholder}"></div> <div class="${BDFDB.disCN.guildplaceholder}"></div>
</foreignObject> </foreignObject>
</svg> </svg>
<div class="${BDFDB.disCN.guildbadgewrapper}"></div>
</div> </div>
</div> </div>
</div> </div>