3stack:colour-picker

A basic, reactive colour picker component


License
MIT
Install
meteor add 3stack:colour-picker@=0.4.0

Documentation

colour-picker

A basic colour picker. Styled to match bootstrap-3.

Usage (Blaze)

Add to a template:

{{> colourPicker
  selectedColour=fillColour
  handleSelect=handleFillSelect
  property='fill'
  menu=true
  allowNone=true
}}

Then, catch events:

Template.myTemplate.helpers({
  fillColour: function(){ return Session.get('someSessionValue'); },
  handleFillSelect: function(){
    return function(colour){
      Session.set('someSessionValue', colour);
    };
  }
});

Options:

selectedColour Should be a reactive value of the currently selected colour.

property Prompts the user eg, 'fill' becomes 'Fill Colour'

allowNone does as it says - allows a transparent or nil colour to be selected.

menu wraps in a bootstrap menu. Write your own like this:

  <div class="btn-group">
    <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown">
      <span class="colour-picker-selected-block" style="background: {{selectedColour}};"></span>&nbsp;&nbsp;<span class="caret"></span>
    </button>
    <div class="dropdown-menu">
      {{> colourPicker selectedColour=selectedColour property='propertyName' menu=false allowNone=true}}
    </div>
    <input name="selectedColour" type="hidden" value="{{selectedColour}}"/>
  </div>

Usage (React)

Menu Style -

<ColourPickerButton
  value={myValue}
  onChange={myFunc}
  title="Fill"
  allowNone=false
/>

Raw Div - Similar to (menu=false) on blaze version

<ColourPickerControl
  value={myValue}
  onChange={myFunc}
  title="Fill"
  allowNone=false
/>

Advanced

Can't think of a decent way to allow the user of the package to provide a colour scheme.

Probably best to fork, and add your own!