• Stars
    star
    561
  • Rank 79,400 (Top 2 %)
  • Language
    JavaScript
  • License
    MIT License
  • Created over 12 years ago
  • Updated about 2 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Scaleable color picker with touch and AMD support (MIT)

colorjoe - The Scaleable Color Picker

colorjoe was somewhat inspired by ColorJack and RightJS Colorpicker. Unlike those it actually scales pretty well. Essentially this means that you'll be able to define its actual dimensions and layout using a bit of CSS. This way the widget fits well responsive layouts.

In addition it's relatively easy to implement missing functionality (RGB fields, whatnot) thanks to the simple API it provides.

Installation

npm i colorjoe

If you prefer a standalone dist, add prepackaged dist/colorjoe.js and css/colorjoe.css to your page or use AMD to load the dependencies from src/.

Usage

const joe = colorjoe.rgb(element_id_or_dom_object, initial_color_value, extras);

or

const joe = colorjoe.hsl(element_id_or_dom_object, initial_color_value, extras);

Event Handling

The returned joe object is an event emitter style object with change and done events. The change event is fired continuously when selecting and done is fired when user has stopped selecting.

joe.on("change", color => console.log("Selecting " + color.css()));
joe.on("done", color => console.log("Selected " + color.css()));

The color object is from one.color.

Given it might be nice to trigger these events immediately, there is a specific update method. Ie. joe.on("change", function() {...}).update() would trigger change immediately. This is handy for initializing your work.

Get and Set

In addition there are set and get methods. Ie. joe.get() would return the current color while joe.set('#aabbcc') would set it. set expects a parameter that one.color default constructor would accept.

Extras

In order to make it easier to customize a picker based on your needs, colorjoe provides a few extras. The following example shows how to use them:

const joe = colorjoe.hsl('hslPicker', 'red', [
    'currentColor',
    'alpha',
    ['fields', {space: 'HSL', limit: 255, fix: 0},
    'hex'
]);

The code above would generate a HSL picker that shows in addition the currently selected color, alpha slider, HSL input fields and a hex field.

As you can see fields has been defined using an array. This array contains the name of the extra and then parameters passed to inside an object. In this case the extra accepts name of a color space (RGB, HSL, HSV or CMYK). If you append A to the color space, it will show a control for alpha too. In addition it takes a limit value (defaults to 255) and a fix value (defaults to 0). fix represents the amount of numbers shown after decimal.

hex extra accepts optional label. If set it will show that as the input's label.

Implementing Custom Extras

It is possible to implement your custom extras without having to hack the core code. This can be done as follows:

colorjoe.registerExtra('text', (p, joe, o) => {
    // attach new elements to p element here (as children that is)
    // o is optional and will contain any parameters you might have
    // passed to the extra using the array syntax

    // optional return. these are triggered by colorjoe
    // use this way instead of joe.on
    return {
        change(col) {},
        done(col) {}
    };
})

Now you can simply pass your text extra amongst the others and it will just work.

Sites Using colorjoe

PRs are welcome!

Contributors

Hacking

  1. npm i
  2. npm start
  3. serve (or similar command) at project root

License

colorjoe is available under MIT. See LICENSE for more details.

More Repositories

1

jswiki

JavaScript wiki. Focuses mainly on JS/HTML5/WebGL related tech.
JavaScript
3,913
star
2

react-pagify

Simple pagination for React (MIT)
JavaScript
142
star
3

Chart.js.legend

**DEPRECATED** Legend plugin for Chart.js (MIT)
JavaScript
114
star
4

grunt-umd

Surrounds code with the universal module definition (MIT)
JavaScript
96
star
5

ghw

Converts your GitHub wiki to gh-pages (MIT)
CSS
63
star
6

invoice-frontend

Invoicing application (MIT)
JavaScript
50
star
7

setjs

Set data structure for JavaScript (MIT)
JavaScript
47
star
8

dragjs

Simple utility to make it easier to implement drag based things (ie. sliders and such) (MIT)
TypeScript
45
star
9

generate-invoice

Generates PDF invoices (MIT)
JavaScript
36
star
10

node-configuration-patterns

Node.js configuration patterns (MIT)
JavaScript
30
star
11

segmentize

Simple segmentation useful for pagination (MIT)
JavaScript
28
star
12

react-ellipsify

Ellipsify content (MIT)
JavaScript
27
star
13

highlight-loader

Applies highlight.js to given HTML (MIT)
JavaScript
25
star
14

swagger-todo

Minimal Todo API example using Swagger on top of Node.js (Express+Sequelize+swagger-tools+jwt) (MIT)
JavaScript
24
star
15

colorjs

Color lib for JS (supports rgba, hsva, hsla via a simple API) (MIT)
JavaScript
20
star
16

yeswejekyll

Yes We Jekyll. Or if we don't yet, we will after reading this guide. Read on.
JavaScript
19
star
17

blogger2ghost

Blogspot JSON migrator plugin for Ghost (MIT)
JavaScript
18
star
18

pingdom-api

Pingdom API client for Node.js (MIT)
JavaScript
17
star
19

react-crm-backend

Backend for CRM (MIT)
JavaScript
15
star
20

react-crm-frontend

Frontend for CRM (MIT)
JavaScript
14
star
21

jquery.ellipsis

Ellipsis plugin for jQuery (MIT)
JavaScript
14
star
22

png2ico

Converts pngs to icos (MIT)
JavaScript
13
star
23

mocss

CSS preprocessor written in Node. Beta quality, wrote this originally for a blogpost. (MIT)
JavaScript
13
star
24

libumd

Wraps given JavaScript code with UMD (MIT)
JavaScript
10
star
25

jquery.caro

Simple, scaleable carousels for jQuery (MIT)
JavaScript
9
star
26

suite.js

Minimalistic testing tool for Node. Supports generative tests (aka QuickCheck). (MIT)
JavaScript
8
star
27

funkit

Various utilities (MIT)
JavaScript
7
star
28

bunit.js

Simple testing lib for JS (MIT)
JavaScript
7
star
29

Placidity

Placidity is an interactive interpreter with simple plugin architecture developed as a part of tutorial series focusing on testing related concepts.
Python
7
star
30

canifont

Figure out what fonts to use (MIT)
JavaScript
6
star
31

yabox.js

Yet another lightbox clone. Very light one this time. (MIT)
JavaScript
6
star
32

reactabular

Redirect to reactabular.js.org
HTML
5
star
33

react-ghfork

GitHub fork image for React (MIT)
CSS
5
star
34

blog-utils

Misc. utils making it easier to write blog posts (MIT)
JavaScript
5
star
35

iterplus

Utilities that complement Python's itertools
Python
5
star
36

replace-project-meta

Replaces project meta from package.json/README.md
JavaScript
5
star
37

speccer

Specification based test runner for Python (MIT)
Python
5
star
38

webpack-add-dependency-plugin

Add dependencies to webpack dev process to watch
TypeScript
4
star
39

jsassert

Chaining assert for JavaScript. Left here more as an example. Currently developed as a part of https://github.com/bebraw/bunit.js .
JavaScript
4
star
40

canvas-dataview-upload

Canvas DataView upload demo (MIT)
JavaScript
4
star
41

readme2gh

Updates your gh sites pages based on README.md (MIT)
JavaScript
4
star
42

styleguidist-ts-sc

Styleguidist demos with TypeScript and Styled Components with Cypress for acceptance testing
JavaScript
4
star
43

lte-scraper

Scrapes LTE data from Apple and Wikipedia and then joins them (MIT)
JavaScript
4
star
44

qdemo

Demonstration generator for jQuery plugins (MIT)
JavaScript
4
star
45

swagger2client

JavaScript client for Swagger 2.0 (MIT)
JavaScript
4
star
46

schema2object

Generate random objects based on JSON Schema (MIT)
JavaScript
4
star
47

turtles.js

Implementation of Turtle Graphics in JavaScript
JavaScript
3
star
48

juke

Simple jukebox using MPD backend
JavaScript
3
star
49

webshotter

Capture multiple screenshots per website (MIT)
JavaScript
3
star
50

jsrunner

Simple test runner (works well with jsassert). Left here more as an example. Currently developed as a part of https://github.com/bebraw/bunit.js .
JavaScript
3
star
51

f500-scraper

Example of a scraper (MIT)
JavaScript
3
star
52

rjs-build-demo

Demo of RequireJS build (weird output)
JavaScript
3
star
53

jquery.tokko.js

Generates a table of contents and anchors based on document headers
JavaScript
3
star
54

deno-demos

Deno demos for ViennaJS coding session (2021-01-27)
TypeScript
3
star
55

reload.js

Reloads page based on given interval (handy for testing esp.) (MIT)
JavaScript
3
star
56

narrative.js

This utility makes it easier to write narrative scripts for Node (MIT)
JavaScript
3
star
57

mojs

JS preprocessor (adds some extra syntax) (MIT)
JavaScript
3
star
58

check-markdown-links

Checks links of Markdown files in the given directory
JavaScript
3
star
59

jsopo

Precompiler providing operator overloading for JavaScript (proof of concept). This project is obsolete and preserved only for learning purposes! See http://nixtu.blogspot.com/2011/05/using-jsshaper-to-provide-operator.html to see how to achieve the same using JSShaper.
Python
3
star
60

sandboxy

Minimal sandbox for JavaScript (MIT)
JavaScript
2
star
61

dotfiles

Just some of my dotfiles
Vim Script
2
star
62

bebraw

2
star
63

jkl-scraper

JavaScript
2
star
64

pynu

Pynu - Python Node Utilities (MIT)
Python
2
star
65

django-navi

Hierarchical navigation plugin for Django
Python
2
star
66

pyqa

Configuration generator (user input -> nice conf) (MIT)
Python
2
star
67

jsdelivr-in-5mins

Intro to jsDelivr in five minutes
JavaScript
2
star
68

really-brief-introduction-to-html5

Presentation slides (still WIP)
1
star
69

recipe-scraper

Scrapes Wikia food recipes (MIT)
JavaScript
1
star
70

react-hot-starter

Hot starting point for React apps (MIT)
JavaScript
1
star
71

really-brief-introduction-to-javascript

Presentation slides
1
star
72

props2query

React props to GraphQL queries prototype. Nothing to see here yet.
TypeScript
1
star
73

tests-in-modules

Jest tests in modules (poc)
JavaScript
1
star
74

parse-env

Parses configuration from env
JavaScript
1
star
75

cassopi

Automatically exported from code.google.com/p/cassopi
Python
1
star
76

cv

My personal resume.
HTML
1
star
77

jquery.center.js

Centering plugin for jQuery (MIT)
JavaScript
1
star
78

nixtu

Nixtu Blog - Source Code
Python
1
star
79

redirect-webpack-plugin

Write redirects using webpack
JavaScript
1
star
80

resolve-swagger-refs

Resolves Swagger 2.0 definition references (MIT)
JavaScript
1
star
81

geekprofile-frontend

Geek Profile frontend
JavaScript
1
star
82

really-brief-introduction-to-django

Presentation slides + support material
Python
1
star
83

swaggerify

Swagger definition helpers for Node.js (MIT)
JavaScript
1
star
84

rekanban

Experimental Kanban app, missing UI atm (MIT)
JavaScript
1
star
85

html-webpack-remark-plugin

Render Markdown to React through Remark (MIT)
JavaScript
1
star
86

react-pure-button

React wrapper for Pure buttons (MIT)
JavaScript
1
star
87

playwright-demo

Tiny playwright demo
JavaScript
1
star
88

grunt-adapter

Executes grunt plugins without grunt itself (MIT)
JavaScript
1
star
89

stalbum

Static album generator (MIT)
JavaScript
1
star
90

fs-demo

Webpack fs bug
JavaScript
1
star
91

react-pure-menu

React wrapper for Pure menus (MIT)
JavaScript
1
star
92

react-sidecar

React wrapper for Gitter sidecar (MIT)
JavaScript
1
star
93

parsegh

Parses url/git string and returns associated GitHub user and repository (MIT)
JavaScript
1
star
94

really-brief-introduction-to-python

Presentation slides
JavaScript
1
star
95

tinytest

py.test inspired unit testing library for PHP (MIT)
PHP
1
star
96

aoc21

Advent of code 2021
TypeScript
1
star
97

ioscript.js

ioscript.js makes it easy to write IO scripts in Node
JavaScript
1
star
98

spyder

Web indexer and scraper runner (MIT)
JavaScript
1
star
99

taskist

Glues your project configuration and tasks together (MIT)
JavaScript
1
star
100

project-defaults

Defaults to share across projects (MIT)
JavaScript
1
star