Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mzusin/toolcool-color-picker

Tool Cool Color Picker is a color picker library written in typescript and using web component technologies.
https://github.com/mzusin/toolcool-color-picker

color-palette color-picker color-picker-library color-pickers color-picking

Last synced: about 1 month ago
JSON representation

Tool Cool Color Picker is a color picker library written in typescript and using web component technologies.

Awesome Lists containing this project

README

        

# Tool Cool Color Picker

[![GitHub license](https://img.shields.io/github/license/mzusin/toolcool-color-picker)](https://github.com/mzusin/toolcool-color-picker/blob/main/LICENSE)
![GitHub package.json version](https://img.shields.io/github/package-json/v/mzusin/toolcool-color-picker)
[![npm](https://img.shields.io/npm/dw/toolcool-color-picker)](https://www.npmjs.com/package/toolcool-color-picker)
[![NPM](https://img.shields.io/badge/npm-color_picker-brightgreen)](https://www.npmjs.com/package/toolcool-color-picker)
[![](https://data.jsdelivr.com/v1/package/npm/toolcool-color-picker/badge?style=rounded)](https://www.jsdelivr.com/package/npm/toolcool-color-picker)

Tool Cool Color Picker is a color picker library written in typescript and using web component technologies.

![Tool Cool Color Picker](https://github.com/mzusin/toolcool-color-picker/blob/main/examples/img/preview/preview-1.png?raw=true)

## Table of contents
- [Demo Page](https://toolcool-color-picker.mzsoft.org/)
- [Basic Usage](#basic-usage)
- [CDN](#cdn)
- [Node.js usage](#nodejs-usage)
- [APIs](#APIs)
- [Listen to the change event](#apis-listen-to-the-change-event)
- [Change Color](#apis-change-color)
- [Get current color in different formats](#apis-get-current-color-in-different-formats)
- [Popup](#apis-popup)
- [Styles](#styles)
- [Button width, height, and padding](#button-width-height-and-padding)
- [TypeScript Usage](#typescript-usage)
- [Usage with React and TypeScript](#usage-with-react-and-typescript)
- [Credits](#credits)
- [License](#license)

## Basic Usage

Download the latest [toolcool-color-picker.min.js](https://github.com/mzusin/toolcool-color-picker/blob/main/dist/toolcool-color-picker.min.js) script:

Add the following html to the page:
```html

```

Or with other color formats:

```html

```

Color picker popup can be aligned to the right:

```html

```

## CDN

The ToolCool Color Picker is also available in the [jsDelivr CND](https://www.jsdelivr.com/package/npm/toolcool-color-picker):

```html

```

## Node.js usage

[![Tool Cool Color Picker](https://nodei.co/npm/toolcool-color-picker.png)](https://npmjs.org/package/toolcool-color-picker)

Color picker may also be included as a [node module](https://www.npmjs.com/package/toolcool-color-picker) using npm:

`npm i toolcool-color-picker`

or with Yarn:

`yarn add toolcool-color-picker`

And then you can include it in your application like this:

```js
import 'toolcool-color-picker';
```

NPM package can fe found [here](https://www.npmjs.com/package/toolcool-color-picker).

## APIs
You can control the color picker by referencing the `toolcool-color-picker` HTML tag.

```html

// get the reference
const $colorPicker = document.getElementById('color-picker-1');

// change color
$colorPicker.color = '#60f542';

// get color
console.log($colorPicker.rgba);

```

## APIs: Listen to the change event

```js
// listen to the color change event
const $colorPicker = document.getElementById('color-picker');

// @param {evt} CustomEvent
$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](https://github.com/scttcper/tinycolor) for color manipulation. Each color format supported by the TinyColor library can be passed in a color property:

```js
const $colorPicker = document.getElementById('color-picker');

// HEX format
$colorPicker.color = '#60f542';

// OR HEX with opacity
$colorPicker.color = '#60f542ff';

// OR rgb
$colorPicker.color = 'rgb(96, 245, 66)';

// OR rgb with opacity
$colorPicker.color = 'rgba(96, 245, 66, 1)';

// OR hsv
$colorPicker.color = 'hsv(110, 73%, 96%)';

// OR hsv with opacity
$colorPicker.color = 'hsva(110, 73%, 96%, 1)';

// OR hsl
$colorPicker.color = 'hsl(110, 90%, 61%)';

// OR hsl with opacity
$colorPicker.color = 'hsla(110, 90%, 61%, 1)';
```

## APIs: Get current color in different formats

```js
const $colorPicker = document.getElementById('color-picker');
$colorPicker.color = '#367E95';

console.log($colorPicker.hex); // #367E95

console.log($colorPicker.hex8); // #367E95FF

console.log($colorPicker.rgb); // rgb(54, 126, 149)

console.log($colorPicker.rgba); // rgba(54, 126, 149, 1)

console.log($colorPicker.hsl); // hsl(195, 47%, 40%)

console.log($colorPicker.hsla); // hsla(195, 47%, 40%, 1)

console.log($colorPicker.hsv); // hsv(195, 64%, 58%)

console.log($colorPicker.hsva); // hsva(195, 64%, 58%, 1)
```

You can also access the color object of the [TinyColor library](https://github.com/scttcper/tinycolor). It should only be used to get color values and should not be modified directly.

```js
console.log($colorPicker.color);
```

## APIs: Popup

Open or close color picker popup with the following API:

```html

const $colorPicker = document.getElementById('color-picker');

// open color picker popup
$colorPicker.opened = true;

// close color picker popup
$colorPicker.opened = false;

```

## Styles
It's possible to control color picker styles through CSS variables:

```css
:root{
/* button */
--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;

/* popup */
--tool-cool-color-picker-popup-bg: #b9b9b9;
--tool-cool-color-picker-popup-border-color: #000;

/* fields */
--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:

```html

```

## Button width, height, and padding

> Thanks to [MGarcia93](https://github.com/MGarcia93) for contributing to this section.

Button size can be changed using **button-width**, **button-height**, and **button-padding** attributes.

```html

```

It's also possible to use the following predefined values:

| Attribute Value | The result size |
|-----------------|-----------------|
| sm | 0.875rem |
| md | 1.2rem |
| lg | 1.5rem |
| xl | 2.25rem |
| 2xl | 3rem |
| 3xl | 3.75rem |
| 4xl | 4.5rem |

For example:

```html

```

## TypeScript Usage

```typescript
import 'toolcool-color-picker';
import ColorPicker from 'toolcool-color-picker';

// ...

const $colorPicker = document.getElementById('color-picker-1') as ColorPicker;

$colorPicker.addEventListener('change', (evt: Event) => {
const customEvent = evt as CustomEvent;
console.log(customEvent.detail.rgba);
});

$colorPicker.hex = '#fefefe';
```

## Usage with React and TypeScript

```typescript
import 'toolcool-color-picker';

declare global {
namespace JSX {
interface IntrinsicElements {
'toolcool-color-picker': any;
}
}
}

const ColorPickerExample = () => {

const colorPickerRef = useRef();

useEffect(() => {

const colorPicker = colorPickerRef.current;

const onColorChange = (evt: Event) => {
const customEvent = evt as CustomEvent;
console.log(customEvent.detail.rgba);
};

colorPicker?.addEventListener('change', onColorChange);

return () => {
colorPicker?.removeEventListener('change', onColorChange);
};
}, []);

return (
;
)
};

export default ColorPickerExample;
```

## Credits
An awesome [TinyColor Library](https://github.com/scttcper/tinycolor)

## License

[MIT license](https://github.com/mzusin/toolcool-color-picker/blob/main/LICENSE)