YUI Library Home

YUI Library Examples: Color Picker Control: Example of Color Picker Built in a Dialog via JavaScript

Color Picker Control: Example of Color Picker Built in a Dialog via JavaScript

This example explores the implementation of a Color Picker Control within the context of a popup Dialog. The control can be called up in the floating Dialog, a color can be chosen, and upon submission of the Color Picker's value the color data is submitted to the server using Dialog's built-in support for Connection Manager.

Click the "Show Color Picker" button to get started. Use the other buttons on the configuration dashboard to explore different configurations of the Color Picker Controls. When you submit your color choice, the example uses Connection Manager to echo back the form fields that were passed to the server.

Server response will be displayed in this area

Using a Color Picker in a Dialog Control

The focus in this example is on the use of Color Picker Control within a Dialog Control.

In many cases, you'll want to use this implementation for Color Picker as it allows you to avoid reserving space inline in the page for the Color Picker interface. Dialog is ideally suited for this purpose because it floats above the page and is designed to collect and submit form data. Here we'll use Dialog's built-in support for Connection Manager and use that mechanism to process the color information gathered via Color Picker.

We'll also use a configuration dashboard that allows us to selectively enable/disable aspects of the Color Picker interface.

Here's the markup we need to get started:

1<!--begin Color Picker configuration dashboard: --> 
2<div> 
3  <button id="show">Show Color Picker</button>  
4  <button id="hide">Hide Color Picker</button> 
5  <button id="btnhsv">Show/hide HSV fields</button> 
6  <button id="btnhex">Show/hide HEX field</button> 
7  <button id="btnrgb">Show/hide RGB field</button> 
8  <button id="btnhexsummary">Show/hide HEX summary info</button> 
9</div> 
10 
11<!--begin Dialog markup in standard module format; see the Container Family 
12    documentation for more about what markup is required for these controls--> 
13<div id="yui-picker-panel" class="yui-picker-panel"
14    <div class="hd">Please choose a color:</div> 
15    <div class="bd"
16        <form name="yui-picker-form" id="yui-picker-form" method="post" action="assets/post.php"
17        <div class="yui-picker" id="yui-picker"></div> 
18        </form> 
19    </div> 
20    <div class="ft"></div> 
21</div> 
22 
23<!--begin form for server response--> 
24<div id="resp">Server response will be displayed in this area</div> 
view plain | print | ?

This markup provides us with a containing element for our Dialog instance (yui-picker-panel) and another containing element for our Color Picker (yui-picker). From here, we can begin our JavaScript. We'll use the Module Pattern to construct our code, beginning by creating a namespace for our example code and some useful shortcuts to commonly-used YUI components.

1//create a namespace object in the example namespace: 
2YAHOO.namespace("example.colorpicker"
3 
4//create a new object for this module: 
5YAHOO.example.colorpicker.inDialog = function() { 
6 
7    //Some shortcuts to use in our example: 
8    var Event=YAHOO.util.Event, 
9        Dom=YAHOO.util.Dom, 
10        lang=YAHOO.lang; 
view plain | print | ?

The object YAHOO.example.colorpicker.inDialog is returned from our anonymous function. Its first member is our init function, wherein we create the Dialog instance:

1//In our initialization function, we'll create the dialog; 
2//in its render event, we'll create our Color Picker instance. 
3init: function() { 
4 
5    // Instantiate the Dialog 
6    this.dialog = new YAHOO.widget.Dialog("yui-picker-panel", {  
7        width : "500px"
8        fixedcenter : true
9        visible : false,  
10        constraintoviewport : true
11        buttons : [ { text:"Submit", handler:this.handleSubmit, isDefault:true }, 
12                    { text:"Cancel", handler:this.handleCancel } ] 
13     }); 
view plain | print | ?

We don't want to create our Color Picker until the Dialog has rendered, so we tie our Color Picker's instantiation block to the Dialog's renderEvent:

1// Once the Dialog renders, we want to create our Color Picker 
2// instance. 
3this.dialog.renderEvent.subscribe(function() { 
4    if (!this.picker) { //make sure that we haven't already created our Color Picker 
5        YAHOO.log("Instantiating the color picker""info""example"); 
6        this.picker = new YAHOO.widget.ColorPicker("yui-picker", { 
7            container: this.dialog, 
8            images: { 
9                PICKER_THUMB: "assets/picker_thumb.png"
10                HUE_THUMB: "assets/hue_thumb.png" 
11            } 
12            //Here are some other configurations we could use for our Picker: 
13            //showcontrols: false,  // default is true, false hides the entire set of controls 
14            //showhexcontrols: true, // default is false 
15            //showhsvcontrols: true  // default is false 
16        }); 
17 
18        //listen to rgbChange to be notified about new values 
19        this.picker.on("rgbChange"function(o) { 
20            YAHOO.log(lang.dump(o), "info""example"); 
21        }); 
22    } 
23});  
view plain | print | ?

Outside of our initialization function, we create success and failure handlers to deal with data as it comes back from Connection Manager. Those are then accessible to us as we initialize, and we can wire them up to our Dialog's callback object:

1// Wire up the success and failure handlers 
2this.dialog.callback = { success: this.handleSuccess, thisfailure: this.handleFailure }; 
view plain | print | ?

The last step in our initialization is to render our dialog:

1// We're all set up with our Dialog's configurations; 
2// now, render the Dialog 
3this.dialog.render(); 
view plain | print | ?

When our YAHOO.example.colorpicker.inDialog object is created, we can then set its init function to fire onDOMReady:

1//The earliest safe moment to instantiate a Dialog (or any 
2//Container element is onDOMReady; we'll initialize then: 
3YAHOO.util.Event.onDOMReady(YAHOO.example.colorpicker.inDialog.init, YAHOO.example.colorpicker.inDialog, true); 
view plain | print | ?

We've only called out some of the more significant parts of this example's code in the description above; to see the full example's source code, view this example via its "new window" button and view the page source.

Configuration for This Example

You can load the necessary JavaScript and CSS for this example from Yahoo's servers. Click here to load the YUI Dependency Configurator with all of this example's dependencies preconfigured.

Copyright © 2009 Yahoo! Inc. All rights reserved.

Privacy Policy - Terms of Service - Copyright Policy - Job Openings