See09/WRTKit/UI/SelectionList.js
author ivanl
Thu, 22 Oct 2009 15:52:58 +0100
changeset 19 f3521a11d878
permissions -rw-r--r--
See 09 widget, version 1.0rc3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
19
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
     1
/*
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
     2
© Copyright 2008 Nokia Corporation. All rights reserved.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
     3
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
     4
IMPORTANT:  The Nokia software ("WRTKit and Example Widget files") is supplied to you by Nokia
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
     5
Corporation (“Nokia”) in consideration of your agreement to the following terms. Your use, installation
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
     6
and/or redistribution of the WRTKit and Example Widget files constitutes acceptance of these terms. If
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
     7
you do not agree with these terms, please do not use, install, or redistribute the WRTKit and Example
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
     8
Widget files.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
     9
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    10
In consideration of your agreement to abide by the following terms, and subject to these terms, Nokia
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    11
grants you a personal, non-exclusive license, under Nokia’s copyrights in the WRTKit and Example
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    12
Widget files, to use, reproduce, and redistribute the WRTKit and Example files, in text form (for HTML,
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    13
CSS, or JavaScript files) or binary form (for associated images), for the sole purpose of creating S60
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    14
Widgets.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    15
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    16
If you redistribute the WRTKit and Example files, you must retain this entire notice in all such
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    17
redistributions of the WRTKit and Example files.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    18
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    19
You may not use the name, trademarks, service marks or logos of Nokia to endorse or promote products
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    20
that include the WRTKit and Example files without the prior written explicit agreement with Nokia.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    21
Except as expressly stated in this notice, no other rights or licenses, express or implied, are granted by
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    22
Nokia herein, including but not limited to any patent rights that may be infringed by your products that
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    23
incorporate the WRTKit and Example files or by other works in which the WRTKit and Example files
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    24
may be incorporated.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    25
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    26
The WRTKit and Example files are provided on an "AS IS" basis.  NOKIA MAKES NO
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    27
WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    28
WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    29
PARTICULAR PURPOSE, REGARDING THE EXAMPLES OR ITS USE AND OPERATION
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    30
ALONE OR IN COMBINATION WITH YOUR PRODUCTS.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    31
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    32
IN NO EVENT SHALL NOKIA BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    33
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    34
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    35
INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE, REPRODUCTION, AND/OR
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    36
DISTRIBUTION OF THE EXAMPLES, HOWEVER CAUSED AND WHETHER UNDER THEORY
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    37
OF CONTRACT, TORT (INCLUDING NEGLIGENCE), STRICT LIABILITY OR OTHERWISE,
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    38
EVEN IF NOKIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    39
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    40
*/
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    41
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    42
///////////////////////////////////////////////////////////////////////////////
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    43
// The SelectionList class implements a single or multi selection control
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    44
// that lets users select one or more options from a list of options.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    45
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    46
// Constructor.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    47
function SelectionList(id, caption, options, multipleSelection, selected) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    48
    if (id != UI_NO_INIT_ID) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    49
        this.init(id, caption, options, multipleSelection, selected);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    50
    }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    51
}
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    52
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    53
// SelectionList inherits from SelectionControl.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    54
SelectionList.prototype = new SelectionControl(UI_NO_INIT_ID);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    55
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    56
// Root element for options.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    57
SelectionList.prototype.optionListElement = null;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    58
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    59
// Array for tracking option elements.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    60
SelectionList.prototype.optionElements = null;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    61
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    62
// Tracking for currently focused option; null if none.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    63
SelectionList.prototype.focusedOption = null;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    64
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    65
// Enabled status.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    66
SelectionList.prototype.enabled = false;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    67
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    68
// Initializer - called from constructor.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    69
SelectionList.prototype.init = function(id, caption, options, multipleSelection, selected) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    70
    uiLogger.debug("SelectionList.init(" + id + ", " + caption + ", " + options + ", " + multipleSelection + ", " + selected + ")");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    71
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    72
    // call superclass initializer
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    73
    SelectionControl.prototype.init.call(this, id, caption, options, multipleSelection, selected);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    74
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    75
    // create option list element
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    76
    this.optionListElement = document.createElement("div");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    77
    this.controlElement.appendChild(this.optionListElement);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    78
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    79
    // the control defaults to enabled
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    80
    this.enabled = true;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    81
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    82
    // init option element arrays
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    83
    this.optionElements = [];
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    84
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    85
    // update the option elements to match the options in this control
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    86
    this.updateOptionElements();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    87
}
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    88
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    89
// Returns the enabled state.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    90
SelectionList.prototype.isEnabled = function() {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    91
    return this.enabled;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    92
}
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    93
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    94
// Sets the enabled state.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    95
SelectionList.prototype.setEnabled = function(enabled) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    96
    uiLogger.debug("SelectionList.setEnabled(" + enabled + ")");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    97
    // switch the state and update the the control
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    98
    this.enabled = enabled;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
    99
    this.updateOptionElements();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   100
}
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   101
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   102
// Sets the focused state for the control.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   103
// Note: This may not always succeed.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   104
SelectionList.prototype.setFocused = function(focused) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   105
    uiLogger.debug("SelectionList.setFocused(" + focused + ")");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   106
    if (this.enabled && this.optionElements.length > 0) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   107
        if (focused) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   108
            this.optionElements[0].link.focus();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   109
        } else {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   110
            this.optionElements[0].link.blur();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   111
        }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   112
    }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   113
}
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   114
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   115
// Sets the currently selected options. Pass a single option in a single selection
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   116
// control or an array of selected controls in a multiple selection control. To
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   117
// deselect all options pass null in a single selection control and an empty array
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   118
// in a multiple selection control.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   119
SelectionList.prototype.setSelected = function(selected) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   120
    // call superclass setSelected()
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   121
    SelectionControl.prototype.setSelected.call(this, selected);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   122
    this.updateStyleFromState();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   123
}
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   124
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   125
// Sets the options in the control.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   126
SelectionList.prototype.setOptions = function(options) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   127
    // call superclass setOptions()
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   128
    SelectionControl.prototype.setOptions.call(this, options);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   129
    this.updateOptionElements();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   130
}
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   131
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   132
// Updates the option elements for the control element.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   133
SelectionList.prototype.updateOptionElements = function() {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   134
    uiLogger.debug("SelectionControl.updateOptionElements()");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   135
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   136
    // start by removing all current options from the option list element
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   137
    while (this.optionListElement.firstChild != null) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   138
        this.optionListElement.removeChild(this.optionListElement.firstChild);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   139
    }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   140
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   141
    // iterate through the options and add (and possibly create) a
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   142
    // properly configured option element for each option
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   143
    for (var i = 0; i < this.options.length; i++) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   144
        // get the option and option element we're working on
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   145
        var option = this.options[i];
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   146
        
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   147
        // option, link and text elements for this option
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   148
        var optionElement;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   149
        var optionLinkElement;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   150
        var optionTextElement;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   151
        
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   152
        // get the elements
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   153
        if (i == this.optionElements.length) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   154
            // we need to create a new option element...
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   155
            optionElement = document.createElement("div");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   156
            
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   157
            // ...and a new option link element...
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   158
            optionLinkElement = document.createElement("a");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   159
            optionLinkElement.href = "JavaScript:void(0)";
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   160
            
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   161
            // ...and a new option text element
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   162
            optionTextElement = document.createElement("span");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   163
            
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   164
            // hook up event listeners to the element
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   165
            var self = this;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   166
            optionLinkElement.addEventListener("focus", function(event) { self.optionFocusStateChanged(event, true); }, false);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   167
            optionLinkElement.addEventListener("blur", function(event) { self.optionFocusStateChanged(event, false); }, false);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   168
            optionElement.addEventListener("mouseover", function() { self.hoverStateChanged(true); }, false);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   169
            optionElement.addEventListener("mouseout", function() { self.hoverStateChanged(false); }, false);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   170
            optionElement.addEventListener("mousedown", function(event) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   171
                                                               self.optionClicked(event)
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   172
                                                               event.stopPropagation();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   173
                                                               event.preventDefault();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   174
                                                        }, true);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   175
            optionElement.addEventListener("keydown", function(event) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   176
                                                            // center and enter trigger the action
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   177
                                                            if (event.keyCode == 0 || event.keyCode == 13) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   178
                                                                self.optionClicked(event)
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   179
                                                                event.stopPropagation();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   180
                                                                event.preventDefault();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   181
                                                            }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   182
                                                      }, true);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   183
            
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   184
            // add the elements to the option element array
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   185
            this.optionElements.push({ option: optionElement, link: optionLinkElement, text: optionTextElement });
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   186
        } else {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   187
            // we already have ready elements so we'll reuse them
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   188
            optionElement = this.optionElements[i].option;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   189
            optionLinkElement = this.optionElements[i].link;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   190
            optionTextElement = this.optionElements[i].text;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   191
            
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   192
            // remove the option link element from its current parent - if any
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   193
            if (optionLinkElement.parentNode != null) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   194
                optionLinkElement.parentNode.removeChild(optionLinkElement);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   195
            }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   196
            
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   197
            // remove the option text element from its current parent - if any
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   198
            if (optionTextElement.parentNode != null) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   199
                optionTextElement.parentNode.removeChild(optionTextElement);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   200
            }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   201
        }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   202
        
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   203
        // set the option text
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   204
        optionTextElement.innerHTML = option.text;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   205
        
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   206
        // hook up the option to the control
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   207
        if (this.enabled) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   208
            // add the option link element to the option element
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   209
            optionElement.appendChild(optionLinkElement);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   210
            // add the text element to the option element
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   211
            optionLinkElement.appendChild(optionTextElement);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   212
        } else {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   213
            // add the text element directly to the control element
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   214
            optionElement.appendChild(optionTextElement);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   215
        }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   216
        // add the option element to the option list element
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   217
        this.optionListElement.appendChild(optionElement);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   218
    }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   219
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   220
    // update the style
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   221
    this.updateStyleFromState();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   222
}
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   223
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   224
// Callback for focus state change events.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   225
SelectionList.prototype.optionFocusStateChanged = function(event, focused) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   226
    uiLogger.debug("SelectionControl.optionFocusStateChanged()");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   227
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   228
    // get the event source option
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   229
    var option = null;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   230
    var optionElement = null;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   231
    for (var i = 0; i < this.optionElements.length; i++) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   232
        optionElement = this.optionElements[i];
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   233
        if (optionElement.link == event.currentTarget) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   234
            option = this.options[i];
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   235
            break;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   236
        }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   237
    }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   238
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   239
    // remember the focused option; or null if none is focused
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   240
    if (focused) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   241
        this.focusedOption = option;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   242
    } else {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   243
        this.focusedOption = null;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   244
    }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   245
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   246
    // call the superclass focus state change handler
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   247
    this.focusStateChanged(focused);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   248
}
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   249
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   250
// Callback for clicks.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   251
SelectionList.prototype.optionClicked = function(event) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   252
    uiLogger.debug("SelectionControl.optionClicked()");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   253
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   254
    // bail out if we're not enabled
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   255
    if (!this.enabled) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   256
        return false;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   257
    }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   258
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   259
    // get the changed option
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   260
    var option = null;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   261
    var optionElement = null;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   262
    for (var i = 0; i < this.optionElements.length; i++) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   263
        optionElement = this.optionElements[i];
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   264
        if (optionElement.option == event.currentTarget) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   265
            option = this.options[i];
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   266
            break;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   267
        }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   268
    }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   269
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   270
    // make sure the option is focused
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   271
    optionElement.link.focus();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   272
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   273
    // toggle the selection
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   274
    if (this.multipleSelection) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   275
        // iterate through the selected options and see if this
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   276
        // option is selected. if not then add it to the selection.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   277
        // if it already is selected then them remove it.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   278
        var found = false;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   279
        for (var i = 0; i < this.selected.length; i++) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   280
            if (this.selected[i] == option) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   281
                // remove from selected set
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   282
                found = true;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   283
                this.selected.splice(i, 1);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   284
                break;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   285
            }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   286
        }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   287
        if (!found) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   288
            // add to the selected set
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   289
            this.selected.push(option);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   290
        }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   291
    } else {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   292
        // update the selected option
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   293
        this.selected = option;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   294
    }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   295
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   296
    // update the style
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   297
    this.updateStyleFromState();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   298
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   299
    // notify event listeners
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   300
    this.fireEvent(this.createEvent("SelectionChanged", this.getSelected()));
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   301
}
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   302
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   303
// Resets the state tracking for focus and hover.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   304
// Override this in subclasses as required to implement the state reset.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   305
SelectionList.prototype.resetFocusState = function() {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   306
    uiLogger.debug("SelectionList.resetFocusState()");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   307
    this.hovering = false;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   308
    this.focused = false;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   309
    this.focusedOption = null;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   310
    this.updateStyleFromState();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   311
}
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   312
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   313
// Updates the style of the control to reflects the state of the control.
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   314
SelectionList.prototype.updateStyleFromState = function() {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   315
    uiLogger.debug("SelectionList.updateStyleFromState()");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   316
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   317
    // determine the state name
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   318
    var stateName = this.getStyleStateName();
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   319
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   320
    // set element class names
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   321
    this.setClassName(this.rootElement, "Control");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   322
    this.setClassName(this.controlElement, "ControlElement");
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   323
    this.setClassName(this.assemblyElement, "ControlAssembly ControlAssembly" + stateName);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   324
    this.setClassName(this.captionElement, "ControlCaption ControlCaption" + stateName);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   325
    
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   326
    // set option list and option class names
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   327
    this.setClassName(this.optionListElement, "SelectionList SelectionList" + stateName);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   328
    for (var i = 0; i < this.options.length; i++) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   329
        var option = this.options[i];
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   330
        
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   331
        // get the option and option text elements for this option
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   332
        var optionElement = this.optionElements[i].option;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   333
        var optionTextElement = this.optionElements[i].text;
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   334
        
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   335
        // figure out the option state
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   336
        var optionStateName = this.isSelected(option) ? "Checked" : "Unchecked";
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   337
        if (!this.enabled) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   338
            optionStateName += "Disabled";
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   339
        } else if (this.focusedOption == option) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   340
            optionStateName += "Focus";
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   341
        } else {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   342
            optionStateName += "Normal";
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   343
        }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   344
        
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   345
        // set option element class names
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   346
        if (this.multipleSelection) {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   347
            this.setClassName(optionElement, "SelectionListOptionMulti SelectionListOptionMulti" + optionStateName);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   348
        } else {
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   349
            this.setClassName(optionElement, "SelectionListOptionSingle SelectionListOptionSingle" + optionStateName);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   350
        }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   351
        
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   352
        // set option text class names
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   353
        this.setClassName(optionTextElement, "SelectionListOptionText SelectionListOptionText" + stateName);
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   354
    }
f3521a11d878 See 09 widget, version 1.0rc3
ivanl
parents:
diff changeset
   355
}