org.symbian.tools.wrttools/projecttemplates/WRTKit/UI/NavigationButton.js
author tasneems@symbian.org
Mon, 01 Feb 2010 13:47:20 -0800
changeset 73 c56c874eef47
child 102 30e0796f3ebb
permissions -rw-r--r--
Added WRTKit
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
73
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
     1
/*
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
     2
© Copyright 2008 Nokia Corporation. All rights reserved.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
     3
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
     4
IMPORTANT:  The Nokia software ("WRTKit and Example Widget files") is supplied to you by Nokia
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
     5
Corporation (“Nokia”) in consideration of your agreement to the following terms. Your use, installation
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
     6
and/or redistribution of the WRTKit and Example Widget files constitutes acceptance of these terms. If
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
     7
you do not agree with these terms, please do not use, install, or redistribute the WRTKit and Example
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
     8
Widget files.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
     9
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    10
In consideration of your agreement to abide by the following terms, and subject to these terms, Nokia
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    11
grants you a personal, non-exclusive license, under Nokia’s copyrights in the WRTKit and Example
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    12
Widget files, to use, reproduce, and redistribute the WRTKit and Example files, in text form (for HTML,
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    13
CSS, or JavaScript files) or binary form (for associated images), for the sole purpose of creating S60
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    14
Widgets.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    15
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    16
If you redistribute the WRTKit and Example files, you must retain this entire notice in all such
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    17
redistributions of the WRTKit and Example files.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    18
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    19
You may not use the name, trademarks, service marks or logos of Nokia to endorse or promote products
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    20
that include the WRTKit and Example files without the prior written explicit agreement with Nokia.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    21
Except as expressly stated in this notice, no other rights or licenses, express or implied, are granted by
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    22
Nokia herein, including but not limited to any patent rights that may be infringed by your products that
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    23
incorporate the WRTKit and Example files or by other works in which the WRTKit and Example files
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    24
may be incorporated.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    25
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    26
The WRTKit and Example files are provided on an "AS IS" basis.  NOKIA MAKES NO
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    27
WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    28
WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    29
PARTICULAR PURPOSE, REGARDING THE EXAMPLES OR ITS USE AND OPERATION
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    30
ALONE OR IN COMBINATION WITH YOUR PRODUCTS.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    31
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    32
IN NO EVENT SHALL NOKIA BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    33
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    34
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    35
INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE, REPRODUCTION, AND/OR
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    36
DISTRIBUTION OF THE EXAMPLES, HOWEVER CAUSED AND WHETHER UNDER THEORY
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    37
OF CONTRACT, TORT (INCLUDING NEGLIGENCE), STRICT LIABILITY OR OTHERWISE,
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    38
EVEN IF NOKIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    39
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    40
*/
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    41
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    42
///////////////////////////////////////////////////////////////////////////////
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    43
// The NavigationButton class implements a button control for use in
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    44
// navigational contexts in menu-style UIs.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    45
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    46
// Constructor.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    47
function NavigationButton(id, image, text) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    48
    if (id != UI_NO_INIT_ID) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    49
        this.init(id, image, text);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    50
    }
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    51
}
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    52
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    53
// NavigationButton inherits from ActionControl.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    54
NavigationButton.prototype = new ActionControl(UI_NO_INIT_ID);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    55
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    56
// Button table element.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    57
NavigationButton.prototype.tableElement = null;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    58
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    59
// Button table row element.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    60
NavigationButton.prototype.tableRowElement = null;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    61
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    62
// Button table left cell element.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    63
NavigationButton.prototype.tableLeftCellElement = null;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    64
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    65
// Button table right cell element.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    66
NavigationButton.prototype.tableRightCellElement = null;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    67
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    68
// Button image element.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    69
NavigationButton.prototype.imageElement = null;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    70
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    71
// Button link element.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    72
NavigationButton.prototype.linkElement = null;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    73
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    74
// Button text element.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    75
NavigationButton.prototype.textElement = null;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    76
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    77
// Initializer - called from constructor.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    78
NavigationButton.prototype.init = function(id, image, text) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    79
    uiLogger.debug("NavigationButton.init(" + id + ", " + image + ", " + text + ")");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    80
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    81
    // call superclass initializer
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    82
    ActionControl.prototype.init.call(this, id, null);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    83
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    84
    // remove caption element
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    85
    this.assemblyElement.removeChild(this.captionElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    86
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    87
    // construct the button
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    88
    this.buttonElement = document.createElement("div");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    89
    this.tableElement = document.createElement("table");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    90
    this.tableRowElement = document.createElement("tr");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    91
    this.tableLeftCellElement = document.createElement("td");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    92
    this.tableRightCellElement = document.createElement("td");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    93
    this.imageElement = null;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    94
    this.linkElement = document.createElement("a");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    95
    this.linkElement.href = "JavaScript:void(0)";
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    96
    this.textElement = document.createElement("span");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    97
    this.tableElement.appendChild(this.tableRowElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    98
    this.tableRowElement.appendChild(this.tableLeftCellElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
    99
    this.tableRowElement.appendChild(this.tableRightCellElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   100
    this.tableRightCellElement.appendChild(this.linkElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   101
    this.linkElement.appendChild(this.textElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   102
    this.buttonElement.appendChild(this.tableElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   103
    this.controlElement.appendChild(this.buttonElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   104
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   105
    // set the image and text
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   106
    this.setImage(image);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   107
    this.setText(text);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   108
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   109
    // bind event listeners
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   110
    this.bindActionControlListeners();
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   111
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   112
    // update the style
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   113
    this.updateStyleFromState();
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   114
}
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   115
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   116
// Sets the enabled state.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   117
NavigationButton.prototype.setEnabled = function(enabled) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   118
    uiLogger.debug("NavigationButton.setEnabled(" + enabled + ")");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   119
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   120
    // bail out early if there is no change in state
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   121
    if (this.enabled == enabled) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   122
        return;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   123
    }
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   124
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   125
    // set the enabled state
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   126
    this.enabled = enabled;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   127
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   128
    if (this.enabled) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   129
        // diabled -> enabled
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   130
        this.tableRightCellElement.removeChild(this.textElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   131
        this.tableRightCellElement.appendChild(this.linkElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   132
        this.linkElement.appendChild(this.textElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   133
    } else {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   134
        // enabled -> diabled
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   135
        this.linkElement.removeChild(this.textElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   136
        this.tableRightCellElement.removeChild(this.linkElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   137
        this.tableRightCellElement.appendChild(this.textElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   138
    }
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   139
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   140
    // update the style
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   141
    this.updateStyleFromState();
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   142
}
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   143
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   144
// Returns the button image (URL); null if none.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   145
NavigationButton.prototype.getImage = function() {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   146
    return (this.imageElement != null) ? this.imageElement.src : null;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   147
}
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   148
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   149
// Sets the button image (URL); null if none.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   150
NavigationButton.prototype.setImage = function(image) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   151
    uiLogger.debug("NavigationButton.setImage(" + image + ")");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   152
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   153
    if (image == null) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   154
        // remove image - if any
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   155
        if (this.imageElement != null) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   156
            this.tableLeftCellElement.removeChild(this.imageElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   157
        }
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   158
    } else {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   159
        // default to not append image element
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   160
        var append = false;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   161
        
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   162
        // create image element if one doesn't exist
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   163
        if (this.imageElement == null) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   164
            this.imageElement = document.createElement("img");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   165
            this.imageElement.setAttribute("alt", "");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   166
            append = true;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   167
        }
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   168
        
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   169
        // set image source URL
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   170
        this.imageElement.src = image;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   171
        
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   172
        // append the image element to the left cell?
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   173
        if (append) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   174
            this.tableLeftCellElement.appendChild(this.imageElement);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   175
        }
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   176
    }
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   177
}
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   178
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   179
// Returns the button text.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   180
NavigationButton.prototype.getText = function() {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   181
    return this.textElement.innerHTML;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   182
}
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   183
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   184
// Sets the button text.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   185
NavigationButton.prototype.setText = function(text) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   186
    uiLogger.debug("NavigationButton.setText(" + text + ")");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   187
    this.textElement.innerHTML = (text == null) ? "" : text;;
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   188
}
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   189
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   190
// Updates the style of the control to reflects the state of the control.
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   191
NavigationButton.prototype.updateStyleFromState = function() {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   192
    uiLogger.debug("NavigationButton.updateStyleFromState()");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   193
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   194
    // determine the state name
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   195
    var stateName = this.getStyleStateName();
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   196
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   197
    // set root element class name
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   198
    this.setClassName(this.rootElement, "Control");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   199
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   200
    // set the control assembly class names
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   201
    this.setClassName(this.assemblyElement, "ControlAssembly ControlAssembly" + stateName);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   202
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   203
    // control element
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   204
    this.setClassName(this.controlElement, "ControlElement NavigationButtonControlElement");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   205
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   206
    // set the button table class names
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   207
    this.setClassName(this.buttonElement, "NavigationButton");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   208
    this.setClassName(this.tableElement, "NavigationButtonTable");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   209
    this.setClassName(this.tableRowElement, "NavigationButtonRow");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   210
    this.setClassName(this.tableLeftCellElement, "NavigationButtonImageCell");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   211
    this.setClassName(this.tableRightCellElement, "NavigationButtonTextCell");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   212
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   213
    // set image class names
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   214
    if (this.imageElement) {
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   215
        this.setClassName(this.imageElement, "NavigationButtonImage");
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   216
    }
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   217
    
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   218
    // set the button text class name
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   219
    this.setClassName(this.textElement, "NavigationButtonText NavigationButtonText" + stateName);
c56c874eef47 Added WRTKit
tasneems@symbian.org
parents:
diff changeset
   220
}