From 1ec16855297810d85eee05bf11dada31b8aadf3e Mon Sep 17 00:00:00 2001 From: peterd Date: Sun, 7 Sep 2014 17:49:36 +0200 Subject: [PATCH] initial jQuery impementation --- README.md | 1 + colorPicker.jquery.json | 28 ++++++ colorPicker.js | 3 +- colors.js | 2 +- index.css | 3 + index.html | 3 +- jQuery_implementation/index.html | 38 +++++++++ jQuery_implementation/jqColor.css | 20 +++++ jQuery_implementation/jqColor.js | 136 ++++++++++++++++++++++++++++++ 9 files changed, 231 insertions(+), 3 deletions(-) create mode 100644 colorPicker.jquery.json create mode 100644 jQuery_implementation/index.html create mode 100644 jQuery_implementation/jqColor.css create mode 100644 jQuery_implementation/jqColor.js diff --git a/README.md b/README.md index 85812f7..3681f27 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,4 @@ + # colorPicker and colors An advanced, fast but small (46.9KB, 19.9KB gZip) **javaScript** (only, framework independent) **color picker** (or color chooser for desktop use) that uses only one javaScript (.js) file (no extra HTML, CSS, images, etc... on IE9+ and internet browsers).
ColorPicker works in all browsers incl. IE6+ (an extra CSS has to be made to make it work in IE6 though and some additional setTimeout tricks to make it work in IE5.5)
diff --git a/colorPicker.jquery.json b/colorPicker.jquery.json new file mode 100644 index 0000000..f60878d --- /dev/null +++ b/colorPicker.jquery.json @@ -0,0 +1,28 @@ +{ + "name": "ColorPicker", + "title": "jQuery-ColorPicker", + "description": "Advanced javaScript color picker for jQuery (rgb, hsv, hsl, hex, cmyk, cmy, XYZ, Lab, alpha, WCAG 2.0, ...)", + "keywords": [ + "color-picker", + "color", + "colour" + ], + "version": "1.0", + "author": { + "name": "Peter Dematté", + "email": "colorPicker@dematte.at", + "url": "http://dematte.at/colorPicker" + }, + "licenses": [ + { + "type": "MIT", + "url": "https://github.com/PitPik/colorPicker/blob/master/MIT-LICENSE.txt" + } + ], + "bugs": "https://github.com/PitPik/colorPicker/issues", + "homepage": "http://dematte.at/colorPicker", + "docs": "https://github.com/PitPik/colorPicker", + "dependencies": { + "jquery": ">=1.7" + } +} \ No newline at end of file diff --git a/colorPicker.js b/colorPicker.js index 1151228..2f21f77 100644 --- a/colorPicker.js +++ b/colorPicker.js @@ -438,10 +438,11 @@ if (_mouseMoveAction) { _startCoords = {pageX: page.X, pageY: page.Y}; - _mainTarget.style.display = 'block'; + _mainTarget.style.display = 'block'; // for resizer... _targetOrigin = getOrigin(_mainTarget); _targetOrigin.width = _nodes.opacity.offsetWidth; // ??????? _targetOrigin.childWidth = _nodes.opacity_slider.offsetWidth; // ??????? + _mainTarget.style.display = ''; // ??? for resizer... _mouseMoveAction(event); addEvent(_isIE ? document.body : window, 'mousemove', _mouseMoveAction); _renderTimer = window[requestAnimationFrame](renderAll); diff --git a/colors.js b/colors.js index 528103e..497a868 100644 --- a/colors.js +++ b/colors.js @@ -345,7 +345,7 @@ var ColorConverter = { txt2color: function(txt) { var color = {}, - parts = txt.replace(/(?:#|\))/, '').split('('), + parts = txt.replace(/(?:#|\)|%)/g, '').split('('), values = (parts[1] || '').split(/,\s*/), type = parts[1] ? parts[0].substr(0, 3) : 'rgb', m = ''; diff --git a/index.css b/index.css index 2eecb63..c414b57 100644 --- a/index.css +++ b/index.css @@ -2,6 +2,9 @@ body{ background-color: #222; background: url(); } +a { + color: #aaaaaa; +} .cp-app { position: relative; float: left; diff --git a/index.html b/index.html index f702811..8eca367 100644 --- a/index.html +++ b/index.html @@ -53,7 +53,8 @@
-
Demo patches: demonstrate how to build color pickers and how Colors' / ColorPicker's API work. Patches are linked to
+
Demo patches: demonstrate how to build color pickers and how Colors' / ColorPicker's API work. Patches are linked to +

See a simple jQuery implementation preview here

diff --git a/jQuery_implementation/index.html b/jQuery_implementation/index.html new file mode 100644 index 0000000..c0900eb --- /dev/null +++ b/jQuery_implementation/index.html @@ -0,0 +1,38 @@ + + + + + + + + + + + + + + colorPicker jQuery implementation example + + + +

Simple jQuery implementation

+Calling the colorPicker on all inputs with the calssName 'color':
$('input.color').colorPicker();
+

+ + + +

+ + + + + + + + + + diff --git a/jQuery_implementation/jqColor.css b/jQuery_implementation/jqColor.css new file mode 100644 index 0000000..e7db498 --- /dev/null +++ b/jQuery_implementation/jqColor.css @@ -0,0 +1,20 @@ +body { + color: #ccc; + padding: .5em 2em; + font: normal normal normal .9em/1.35em Georgia, "Times New Roman", Times, serif; +} +input:focus { + outline: none; +} +pre { + display: inline; + background-color: rgba(255, 255, 255, .2); + padding: .5em; +} +.color { + padding: .5em; + margin-right: .4em; + border: 1px solid #aaa; + border-radius: 3px; + width: 140px; +} \ No newline at end of file diff --git a/jQuery_implementation/jqColor.js b/jQuery_implementation/jqColor.js new file mode 100644 index 0000000..1d06bcc --- /dev/null +++ b/jQuery_implementation/jqColor.js @@ -0,0 +1,136 @@ +(function ($, window) { + $.fn.extend({ + colorPicker: function(config) { + var renderCallback = function(colors, mode) { + var options = this, + $input = $(options.input), + $patch = $(options.patch), + RGB = colors.RND.rgb, + HSL = colors.RND.hsl, + AHEX = options.isIE8 ? (colors.alpha < 0.16 ? '0' : '') + + (Math.round(colors.alpha * 100)).toString(16).toUpperCase() + colors.HEX : '', + RGBInnerText = RGB.r + ', ' + RGB.g + ', ' + RGB.b, + RGBAText = 'rgba(' + RGBInnerText + ', ' + colors.alpha + ')', + isAlpha = colors.alpha !== 1 && !options.isIE8, + colorMode = $input.data('colorMode'); + + $patch.css({ + 'color': (colors.rgbaMixBlack.luminance > 0.22 ? '#222' : '#ddd'), // Black...??? + 'background-color': RGBAText, + 'filter' : (options.isIE8 ? 'progid:DXImageTransform.Microsoft.gradient(' + // IE<9 + 'startColorstr=#' + AHEX + ',' + 'endColorstr=#' + AHEX + ')' : '') + }); + + $input.val(colorMode === 'HEX' && !isAlpha ? '#' + (options.isIE8 ? AHEX : colors.HEX) : + colorMode === 'rgb' || (colorMode === 'HEX' && isAlpha) ? + (!isAlpha ? 'rgb(' + RGBInnerText + ')' : RGBAText) : + ('hsl' + (isAlpha ? 'a(' : '(') + HSL.h + ', ' + HSL.s + '%, ' + HSL.l + '%' + + (isAlpha ? ', ' + colors.alpha : '') + ')') + ); + + if (options.displayCallback) { + options.displayCallback(colors, mode, options); + } + }, + createInstance = function(elm, config) { + var initConfig = { + klass: window.ColorPicker, + input: elm, + patch: elm, + isIE8: document.all && !document.addEventListener, // Opera??? + animationSpeed: 200, + draggable: true, + margin: {left: -1, top: 2}, + // displayCallback: displayCallback, + /* --- regular colorPicker options from this point --- */ + color: elm.value, + initStyle: 'display: none', + mode: 'hsv-h', + size: 1, + renderCallback: renderCallback + }; + + for (var n in config) { + initConfig[n] = config[n]; + } + return new initConfig.klass(initConfig); + }, + doEventListeners = function(elm, multiple, off) { + var onOff = off ? 'off' : 'on'; + + $(elm)[onOff]('focus.colorPicker', function(e) { + var $input = $(this), + position = $input.position(), + index = multiple ? $(that).index(this) : 0, + colorPicker = colorPickers[index] || + (colorPickers[index] = createInstance(this, config)), + options = colorPicker.color.options, + $colorPicker = $.ui && options.draggable ? + $(colorPicker.nodes.colorPicker).draggable( + {cancel: '.' + options.CSSPrefix + 'app div'} + ) : $(colorPicker.nodes.colorPicker); + + $colorPicker.css({ + 'position': 'absolute', + 'left': position.left + options.margin.left, + 'top': position.top + +$input.outerHeight(true) + options.margin.top + }); + if (!multiple) { + options.input = elm; + options.patch = elm; // check again??? + colorPicker.setColor(elm.value, undefined, undefined, true); + colorPicker.saveAsBackground(); + } + colorPickers.current = colorPickers[index]; + $colorPicker.show(colorPicker.color.options.animationSpeed); + }); + + if (!colorPickers.evt || off) { + colorPickers.evt = true; // prevent new eventListener for window + + $(window)[onOff]('mousedown.colorPicker', function(e) { + var colorPicker = colorPickers.current, + $colorPicker = $(colorPicker ? colorPicker.nodes.colorPicker : undefined), + animationSpeed = colorPicker ? colorPicker.color.options.animationSpeed : 0, + isColorPicker = $(e.target).closest('.cp-app')[0], + inputIndex = $(that).index(e.target); + + if (isColorPicker && $(colorPickers).index(isColorPicker)) { + if (e.target === colorPicker.nodes.exit) { + $colorPicker.hide(animationSpeed); + $(':focus').trigger('blur'); + } else { + $(document.body).append(isColorPicker); + } + } else if (inputIndex !== -1) { + // input field + } else { + $colorPicker.hide(animationSpeed); + } + }); + } + }, + that = this, + colorPickers = this.colorPickers || []; // this is a way to prevent data binding on HTMLElements + + this.colorPickers = colorPickers; + + $(this).each(function(idx, elm) { + if (config === 'destroy') { + // doEventListeners(elm, (config && config.multipleInstances), true); + $(elm).off('.colorPicker'); + $(window).off('.colorPicker'); + if (colorPickers[idx]) { + colorPickers[idx].destroyAll(); + } + } else { + var value = elm.value.split('('); + $(elm).data('colorMode', value[1] ? value[0].substr(0, 3) : 'HEX'); + doEventListeners(elm, (config && config.multipleInstances), false); + } + }); + + return this; + } + }); +})(jQuery, this); \ No newline at end of file