Long story short: needing a compact solution to insert a standard colorpicker with gradient support in LCweb WordPress plugins, didn't find anything really satisfactory. So I decided to build my own solution in pure javascript aiming to create the most compact and flexible plugin I could for modern web apps.
- sigle 34KB file, no dependencies, 100% pure javascript
- supports solid color and/on linear gradient and/or radial gradient
- unlimited gradient color steps support
- optional transparency support
- light/dark theme
- adjustable in-field preview
- mobile ready
- multilanguage ready
Tested on all mordern browsers (don't ask for old IE support please) For live demos check: https://lcweb.it/lc-color-picker-javascript-plugin
-
include lc_color_picker.min.js
-
initialize plugin targeting one/multiple text fields
<script type="text/javascript> new lc_color_picker('input'); </script> By default, the plugin will wrap targeted fields with an inline-block DIV. However if you are using percentage sizes on inputs, their sizes could be corrupted. In this case you have two options:
-
enable the copy_input_width parameter (NB: static width)
-
edit your CSS targeting the the plugin's wrap element, applying sizes also to it. The CSS selector is .lccp-el-wrap
Here are listed available options with default values
<script type="text/javascript> new lc_color_picker('input', { // (array) containing supported modes (solid | linear-gradient | radial-gradient) modes : ['solid', 'linear-gradient', 'radial-gradient'], // (bool) whether to allow colors transparency tune transparency : true, // (bool) whether to open the picker when field is focused open_on_focus : true, // (bool) whether to enable dark picker theme dark_theme : false, // (bool) whether to stretch the trigger in order to cover the whole input field no_input_mode : false, // (string) defines the wrapper width. "auto" to leave it up to CSS, "inherit" to statically copy input field width, or any other CSS sizing wrap_width : 'auto', // (object) defining shape and position of the in-field preview preview_style : { input_padding : 35, // extra px padding eventually added to the target input to not cover text side : 'right', // right or left width : 30, separator_color : '#ccc', // (string) CSS color applird to preview element as separator }, // (array) defining default colors used when trigger field has no value. First parameter for solid color, second for gradient fallback_colors : ['#008080', 'linear-gradient(90deg, #fff 0%, #000 100%)'], // (function) triggered every time field value changes. Passes value and target field object as parameters on_change : null, // function(new_value, target_field) {}, // (array) option used to translate script texts labels : [ 'click to change color', 'Solid', 'Linear Gradient', 'Radial Gradient', 'add gradient step', 'gradient angle', 'gradient shape', 'color', 'opacity', ], }); </script> Copyright © Luca Montanari - LCweb
