src/cm/media/js/lib/yui/yui_3.10.3/build/slider-value-range/slider-value-range.js
author Yves-Marie Haussonne <ymh.work+github@gmail.com>
Fri, 09 May 2014 18:35:26 +0200
changeset 656 a84519031134
parent 525 89ef5ed3c48b
permissions -rw-r--r--
add link to "privacy policy" in the header test
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
525
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     1
/*
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     2
YUI 3.10.3 (build 2fb5187)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     3
Copyright 2013 Yahoo! Inc. All rights reserved.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     4
Licensed under the BSD License.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     5
http://yuilibrary.com/license/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     6
*/
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     7
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     8
YUI.add('slider-value-range', function (Y, NAME) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
     9
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    10
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    11
 * Adds value support for Slider as a range of integers between a configured
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    12
 * minimum and maximum value.  For use with <code>Y.Base.build(..)</code> to
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    13
 * add the plumbing to <code>Y.SliderBase</code>.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    14
 *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    15
 * @module slider
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    16
 * @submodule slider-value-range
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    17
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    18
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    19
// Constants for compression or performance
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    20
var MIN       = 'min',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    21
    MAX       = 'max',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    22
    VALUE     = 'value',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    23
//     MINORSTEP = 'minorStep',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    24
//     MAJORSTEP = 'majorStep',
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    25
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    26
    round = Math.round;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    27
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    28
/**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    29
 * One class of value algorithm that can be built onto SliderBase.  By default,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    30
 * values range between 0 and 100, but you can configure these on the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    31
 * built Slider class by setting the <code>min</code> and <code>max</code>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    32
 * configurations.  Set the initial value (will cause the thumb to move to the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    33
 * appropriate location on the rail) in configuration as well if appropriate.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    34
 *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    35
 * @class SliderValueRange
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    36
 */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    37
function SliderValueRange() {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    38
    this._initSliderValueRange();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    39
}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    40
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    41
Y.SliderValueRange = Y.mix( SliderValueRange, {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    42
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    43
    // Prototype properties and methods that will be added onto host class
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    44
    prototype: {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    45
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    46
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    47
         * Factor used to translate value -&gt; position -&gt; value.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    48
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    49
         * @property _factor
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    50
         * @type {Number}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    51
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    52
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    53
        _factor: 1,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    54
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    55
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    56
         * Stub for construction logic.  Override if extending this class and
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    57
         * you need to set something up during the initializer phase.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    58
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    59
         * @method _initSliderValueRange
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    60
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    61
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    62
        _initSliderValueRange: function () {},
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    63
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    64
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    65
         * Override of stub method in SliderBase that is called at the end of
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    66
         * its bindUI stage of render().  Subscribes to internal events to
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    67
         * trigger UI and related state updates.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    68
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    69
         * @method _bindValueLogic
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    70
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    71
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    72
        _bindValueLogic: function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    73
            this.after( {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    74
                minChange  : this._afterMinChange,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    75
                maxChange  : this._afterMaxChange,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    76
                valueChange: this._afterValueChange
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    77
            } );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    78
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    79
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    80
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    81
         * Move the thumb to appropriate position if necessary.  Also resets
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    82
         * the cached offsets and recalculates the conversion factor to
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    83
         * translate position to value.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    84
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    85
         * @method _syncThumbPosition
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    86
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    87
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    88
        _syncThumbPosition: function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    89
            this._calculateFactor();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    90
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    91
            this._setPosition( this.get( VALUE ) );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    92
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    93
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    94
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    95
         * Calculates and caches
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    96
         * (range between max and min) / (rail length)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    97
         * for fast runtime calculation of position -&gt; value.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    98
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
    99
         * @method _calculateFactor
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   100
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   101
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   102
        _calculateFactor: function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   103
            var length    = this.get( 'length' ),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   104
                thumbSize = this.thumb.getStyle( this._key.dim ),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   105
                min       = this.get( MIN ),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   106
                max       = this.get( MAX );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   107
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   108
            // The default thumb width is based on Sam skin's thumb dimension.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   109
            // This attempts to allow for rendering off-DOM, then attaching
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   110
            // without the need to call syncUI().  It is still recommended
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   111
            // to call syncUI() in these cases though, just to be sure.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   112
            length = parseFloat( length ) || 150;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   113
            thumbSize = parseFloat( thumbSize ) || 15;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   114
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   115
            this._factor = ( max - min ) / ( length - thumbSize );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   116
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   117
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   118
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   119
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   120
         * Dispatch the new position of the thumb into the value setting
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   121
         * operations.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   122
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   123
         * @method _defThumbMoveFn
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   124
         * @param e { EventFacade } The host's thumbMove event
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   125
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   126
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   127
        _defThumbMoveFn: function ( e ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   128
            // To prevent set('value', x) from looping back around
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   129
            if (e.source !== 'set') {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   130
                this.set(VALUE, this._offsetToValue(e.offset));
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   131
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   132
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   133
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   134
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   135
         * <p>Converts a pixel position into a value.  Calculates current
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   136
         * thumb offset from the leading edge of the rail multiplied by the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   137
         * ratio of <code>(max - min) / (constraining dim)</code>.</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   138
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   139
         * <p>Override this if you want to use a different value mapping
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   140
         * algorithm.</p>
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   141
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   142
         * @method _offsetToValue
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   143
         * @param offset { Number } X or Y pixel offset
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   144
         * @return { mixed } Value corresponding to the provided pixel offset
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   145
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   146
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   147
        _offsetToValue: function ( offset ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   148
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   149
            var value = round( offset * this._factor ) + this.get( MIN );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   150
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   151
            return round( this._nearestValue( value ) );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   152
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   153
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   154
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   155
         * Converts a value into a pixel offset for use in positioning
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   156
         * the thumb according to the reverse of the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   157
         * <code>_offsetToValue( xy )</code> operation.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   158
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   159
         * @method _valueToOffset
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   160
         * @param val { Number } The value to map to pixel X or Y position
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   161
         * @return { Number } The pixel offset 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   162
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   163
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   164
        _valueToOffset: function ( value ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   165
            var offset = round( ( value - this.get( MIN ) ) / this._factor );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   166
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   167
            return offset;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   168
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   169
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   170
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   171
         * Returns the current value.  Override this if you want to introduce
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   172
         * output formatting. Otherwise equivalent to slider.get( "value" );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   173
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   174
         * @method getValue
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   175
         * @return {Number}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   176
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   177
        getValue: function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   178
            return this.get( VALUE );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   179
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   180
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   181
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   182
         * Updates the current value.  Override this if you want to introduce
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   183
         * input value parsing or preprocessing.  Otherwise equivalent to
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   184
         * slider.set( "value", v );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   185
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   186
         * @method setValue
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   187
         * @param val {Number} The new value
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   188
         * @return {Slider}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   189
         * @chainable
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   190
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   191
        setValue: function ( val ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   192
            return this.set( VALUE, val );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   193
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   194
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   195
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   196
         * Update position according to new min value.  If the new min results
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   197
         * in the current value being out of range, the value is set to the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   198
         * closer of min or max.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   199
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   200
         * @method _afterMinChange
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   201
         * @param e { EventFacade } The <code>min</code> attribute change event.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   202
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   203
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   204
        _afterMinChange: function ( e ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   205
            this._verifyValue();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   206
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   207
            this._syncThumbPosition();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   208
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   209
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   210
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   211
         * Update position according to new max value.  If the new max results
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   212
         * in the current value being out of range, the value is set to the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   213
         * closer of min or max.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   214
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   215
         * @method _afterMaxChange
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   216
         * @param e { EventFacade } The <code>max</code> attribute change event.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   217
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   218
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   219
        _afterMaxChange: function ( e ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   220
            this._verifyValue();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   221
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   222
            this._syncThumbPosition();
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   223
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   224
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   225
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   226
         * Verifies that the current value is within the min - max range.  If
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   227
         * not, value is set to either min or max, depending on which is
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   228
         * closer.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   229
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   230
         * @method _verifyValue
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   231
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   232
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   233
        _verifyValue: function () {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   234
            var value   = this.get( VALUE ),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   235
                nearest = this._nearestValue( value );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   236
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   237
            if ( value !== nearest ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   238
                // @TODO Can/should valueChange, minChange, etc be queued
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   239
                // events? To make dd.set( 'min', n ); execute after minChange
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   240
                // subscribers before on/after valueChange subscribers.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   241
                this.set( VALUE, nearest );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   242
            }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   243
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   244
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   245
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   246
         * Propagate change to the thumb position unless the change originated
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   247
         * from the thumbMove event.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   248
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   249
         * @method _afterValueChange
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   250
         * @param e { EventFacade } The <code>valueChange</code> event.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   251
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   252
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   253
        _afterValueChange: function ( e ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   254
            var val = e.newVal;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   255
            this._setPosition( val, { source: 'set' } );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   256
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   257
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   258
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   259
         * Positions the thumb and its ARIA attributes in accordance with the 
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   260
         * translated value.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   261
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   262
         * @method _setPosition
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   263
         * @param value {Number} Value to translate to a pixel position
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   264
         * @param [options] {Object} Details object to pass to `_uiMoveThumb`
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   265
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   266
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   267
        _setPosition: function ( value, options ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   268
            this._uiMoveThumb( this._valueToOffset( value ), options );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   269
            this.thumb.set('aria-valuenow', value);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   270
            this.thumb.set('aria-valuetext', value);
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   271
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   272
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   273
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   274
         * Validates new values assigned to <code>min</code> attribute.  Numbers
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   275
         * are acceptable.  Override this to enforce different rules.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   276
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   277
         * @method _validateNewMin
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   278
         * @param value {Any} Value assigned to <code>min</code> attribute.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   279
         * @return {Boolean} True for numbers.  False otherwise.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   280
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   281
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   282
        _validateNewMin: function ( value ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   283
            return Y.Lang.isNumber( value );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   284
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   285
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   286
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   287
         * Validates new values assigned to <code>max</code> attribute.  Numbers
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   288
         * are acceptable.  Override this to enforce different rules.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   289
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   290
         * @method _validateNewMax
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   291
         * @param value { mixed } Value assigned to <code>max</code> attribute.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   292
         * @return { Boolean } True for numbers.  False otherwise.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   293
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   294
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   295
        _validateNewMax: function ( value ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   296
            return Y.Lang.isNumber( value );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   297
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   298
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   299
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   300
         * Restricts new values assigned to <code>value</code> attribute to be
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   301
         * between the configured <code>min</code> and <code>max</code>.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   302
         * Rounds to nearest integer value.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   303
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   304
         * @method _setNewValue
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   305
         * @param value { Number } Value assigned to <code>value</code> attribute
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   306
         * @return { Number } Normalized and constrained value
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   307
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   308
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   309
        _setNewValue: function ( value ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   310
            return round( this._nearestValue( value ) );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   311
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   312
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   313
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   314
         * Returns the nearest valid value to the value input.  If the provided
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   315
         * value is outside the min - max range, accounting for min > max
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   316
         * scenarios, the nearest of either min or max is returned.  Otherwise,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   317
         * the provided value is returned.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   318
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   319
         * @method _nearestValue
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   320
         * @param value { mixed } Value to test against current min - max range
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   321
         * @return { Number } Current min, max, or value if within range
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   322
         * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   323
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   324
        _nearestValue: function ( value ) {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   325
            var min = this.get( MIN ),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   326
                max = this.get( MAX ),
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   327
                tmp;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   328
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   329
            // Account for reverse value range (min > max)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   330
            tmp = ( max > min ) ? max : min;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   331
            min = ( max > min ) ? min : max;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   332
            max = tmp;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   333
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   334
            return ( value < min ) ?
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   335
                    min :
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   336
                    ( value > max ) ?
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   337
                        max :
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   338
                        value;
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   339
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   340
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   341
    },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   342
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   343
    /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   344
     * Attributes that will be added onto host class.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   345
     *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   346
     * @property ATTRS
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   347
     * @type {Object}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   348
     * @static
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   349
     * @protected
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   350
     */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   351
    ATTRS: {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   352
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   353
         * The value associated with the farthest top, left position of the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   354
         * rail.  Can be greater than the configured <code>max</code> if you
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   355
         * want values to increase from right-to-left or bottom-to-top.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   356
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   357
         * @attribute min
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   358
         * @type { Number }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   359
         * @default 0
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   360
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   361
        min: {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   362
            value    : 0,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   363
            validator: '_validateNewMin'
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   364
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   365
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   366
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   367
         * The value associated with the farthest bottom, right position of
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   368
         * the rail.  Can be less than the configured <code>min</code> if
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   369
         * you want values to increase from right-to-left or bottom-to-top.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   370
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   371
         * @attribute max
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   372
         * @type { Number }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   373
         * @default 100
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   374
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   375
        max: {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   376
            value    : 100,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   377
            validator: '_validateNewMax'
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   378
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   379
        
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   380
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   381
         * amount to increment/decrement the Slider value
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   382
         * when the arrow up/down/left/right keys are pressed
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   383
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   384
         * @attribute minorStep
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   385
         * @type {Number}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   386
         * @default 1
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   387
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   388
        minorStep : {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   389
            value: 1
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   390
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   391
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   392
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   393
         * amount to increment/decrement the Slider value
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   394
         * when the page up/down keys are pressed
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   395
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   396
         * @attribute majorStep
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   397
         * @type {Number}
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   398
         * @default 10
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   399
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   400
        majorStep : {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   401
            value: 10
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   402
        },
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   403
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   404
        /**
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   405
         * The value associated with the thumb's current position on the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   406
         * rail. Defaults to the value inferred from the thumb's current
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   407
         * position. Specifying value in the constructor will move the
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   408
         * thumb to the position that corresponds to the supplied value.
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   409
         *
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   410
         * @attribute value
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   411
         * @type { Number }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   412
         * @default (inferred from current thumb position)
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   413
         */
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   414
        value: {
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   415
            value : 0,
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   416
            setter: '_setNewValue'
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   417
        }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   418
    }
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   419
}, true );
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   420
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   421
89ef5ed3c48b Upgrades to yui 3.10.3
gibus
parents:
diff changeset
   422
}, '3.10.3', {"requires": ["slider-base"]});