mirror of
				https://github.com/BookStackApp/BookStack.git
				synced 2025-11-04 13:31:45 +03:00 
			
		
		
		
	- Also extracted the view code into it's own blade template - Made smaller color input styles
		
			
				
	
	
		
			62 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			62 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;
 |