Tool Cool Color Picker
Tool Cool Color Picker is a color picker library written in typescript and using web component technologies. Check out the demo at https://toolcool.org/toolcool-color-picker/
Basic usage in a browser
Download toolcool-color-picker.min.js
Add the following html to the page:
<toolcool-color-picker color="#e76ff1"></toolcool-color-picker>
<script type="text/javascript" src="toolcool-color-picker.min.js"></script>
Or with other color formats:
<toolcool-color-picker color="rgb(96, 245, 66)"></toolcool-color-picker>
<toolcool-color-picker color="rgba(96, 245, 66, 1)"></toolcool-color-picker>
<toolcool-color-picker color="hsv(110, 73%, 96%)"></toolcool-color-picker>
<toolcool-color-picker color="hsva(110, 73%, 96%, 1)"></toolcool-color-picker>
<toolcool-color-picker color="hsl(110, 90%, 61%)"></toolcool-color-picker>
<toolcool-color-picker color="hsla(110, 90%, 61%, 1)"></toolcool-color-picker>
<script type="text/javascript" src="toolcool-color-picker.min.js"></script>
Color picker popup can be aligned to the right:
<toolcool-color-picker color="rgb(255, 200, 10)" popup-position="right"></toolcool-color-picker>
Node.js usage
Color picker may also be included as a node module like this:
npm i toolcool-color-picker
And then you can include it in your application like this:
import 'toolcool-color-picker';
NPM package can fe found here.
APIs
You can control the color picker by referencing the toolcool-color-picker
HTML tag.
<toolcool-color-picker color="#e76ff1" id="color-picker-1"></toolcool-color-picker>
<script type='text/javascript' src='toolcool-color-picker.min.js'></script>
<script>
const $colorPicker = document.getElementById('color-picker-1');
$colorPicker.color = '#60f542';
console.log($colorPicker.rgba);
</script>
APIs: Listen to the change event
const $colorPicker = document.getElementById('color-picker');
$colorPicker.addEventListener('change', (evt) => {
console.log(evt.detail.hex);
console.log(evt.detail.hex8);
console.log(evt.detail.rgb);
console.log(evt.detail.rgba);
console.log(evt.detail.hsl);
console.log(evt.detail.hsla);
console.log(evt.detail.hsv);
console.log(evt.detail.hsva);
console.log(evt.detail.color);
});
APIs: Change Color
The color picker uses the awesome TinyColor library for color manipulation. Each color format supported by the TinyColor library can be passed in a color property:
const $colorPicker = document.getElementById('color-picker');
$colorPicker.color = '#60f542';
$colorPicker.color = '#60f542ff';
$colorPicker.color = 'rgb(96, 245, 66)';
$colorPicker.color = 'rgba(96, 245, 66, 1)';
$colorPicker.color = 'hsv(110, 73%, 96%)';
$colorPicker.color = 'hsva(110, 73%, 96%, 1)';
$colorPicker.color = 'hsl(110, 90%, 61%)';
$colorPicker.color = 'hsla(110, 90%, 61%, 1)';
APIs: Get current color in different formats
const $colorPicker = document.getElementById('color-picker');
$colorPicker.color = '#367E95';
console.log($colorPicker.hex);
console.log($colorPicker.hex8);
console.log($colorPicker.rgb);
console.log($colorPicker.rgba);
console.log($colorPicker.hsl);
console.log($colorPicker.hsla);
console.log($colorPicker.hsv);
console.log($colorPicker.hsva);
You can also access the color object of the TinyColor library. It should only be used to get color values and should not be modified directly.
console.log($colorPicker.color);
Open or close color picker popup with the following API:
<toolcool-color-picker color="#e76ff1" id="color-picker"></toolcool-color-picker>
<script src="js/toolcool-color-picker.min.js"></script>
<script>
const $colorPicker = document.getElementById('color-picker');
$colorPicker.opened = true;
$colorPicker.opened = false;
</script>
Styles
It's possible to control color picker styles through CSS variables:
:root{
--tool-cool-color-picker-btn-bg: #b9b9b9;
--tool-cool-color-picker-btn-border-color: #000;
--tool-cool-color-picker-btn-border-color-inner: #363636;
--tool-cool-color-picker-btn-border-radius: 1rem;
--tool-cool-color-picker-btn-border-radius-inner: 1rem;
--tool-cool-color-picker-popup-bg: #b9b9b9;
--tool-cool-color-picker-popup-border-color: #000;
--tool-cool-color-picker-field-border-color: #363636;
--tool-cool-color-picker-field-label-color: #1a3c6e;
}
It's also possible to use CSS variables as inline styles in the following way:
<toolcool-color-picker
color="rgb(255, 200, 10)"
style="--tool-cool-color-picker-btn-bg: #fff"></toolcool-color-picker>
TypeScript Usage
import ColorPicker from 'toolcool-color-picker/src/app/color-picker';
const $colorPicker = document.getElementById('get-color-picker') as ColorPicker;
$colorPicker.addEventListener('change', (evt: Event) => {
const customEvent = evt as CustomEvent;
console.log(customEvent.detail.rgba);
});
$colorPicker.hex = '#fefefe';
Credits
An awesome TinyColor Library
License
MIT license