cee4dccc55
- Also extracted the view code into it's own blade template - Made smaller color input styles
61 lines
2.2 KiB
JavaScript
61 lines
2.2 KiB
JavaScript
|
|
class SettingAppColorPicker {
|
|
|
|
constructor(elem) {
|
|
this.elem = elem;
|
|
this.colorInput = elem.querySelector('input[type=color]');
|
|
this.lightColorInput = elem.querySelector('input[name="setting-app-color-light"]');
|
|
this.resetButton = elem.querySelector('[setting-app-color-picker-reset]');
|
|
this.defaultButton = elem.querySelector('[setting-app-color-picker-default]');
|
|
|
|
this.colorInput.addEventListener('change', this.updateColor.bind(this));
|
|
this.colorInput.addEventListener('input', this.updateColor.bind(this));
|
|
this.resetButton.addEventListener('click', event => {
|
|
this.colorInput.value = this.colorInput.dataset.current;
|
|
this.updateColor();
|
|
});
|
|
this.defaultButton.addEventListener('click', event => {
|
|
this.colorInput.value = this.colorInput.dataset.default;
|
|
this.updateColor();
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Update the app colors as a preview, and create a light version of the color.
|
|
*/
|
|
updateColor() {
|
|
const hexVal = this.colorInput.value;
|
|
const rgb = this.hexToRgb(hexVal);
|
|
const rgbLightVal = 'rgba('+ [rgb.r, rgb.g, rgb.b, '0.15'].join(',') +')';
|
|
|
|
this.lightColorInput.value = rgbLightVal;
|
|
|
|
const customStyles = document.getElementById('custom-styles');
|
|
const oldColor = customStyles.getAttribute('data-color');
|
|
const oldColorLight = customStyles.getAttribute('data-color-light');
|
|
|
|
customStyles.innerHTML = customStyles.innerHTML.split(oldColor).join(hexVal);
|
|
customStyles.innerHTML = customStyles.innerHTML.split(oldColorLight).join(rgbLightVal);
|
|
|
|
customStyles.setAttribute('data-color', hexVal);
|
|
customStyles.setAttribute('data-color-light', rgbLightVal);
|
|
}
|
|
|
|
/**
|
|
* Covert a hex color code to rgb components.
|
|
* @attribution https://stackoverflow.com/a/5624139
|
|
* @param hex
|
|
* @returns {*}
|
|
*/
|
|
hexToRgb(hex) {
|
|
const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
|
|
return {
|
|
r: result ? parseInt(result[1], 16) : 0,
|
|
g: result ? parseInt(result[2], 16) : 0,
|
|
b: result ? parseInt(result[3], 16) : 0
|
|
};
|
|
}
|
|
|
|
}
|
|
|
|
export default SettingAppColorPicker;
|