Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
YUI.add('widget-skin', function (Y, NAME) {
2
 
3
/**
4
 * Provides skin related utlility methods.
5
 *
6
 * @module widget
7
 * @submodule widget-skin
8
 */
9
var BOUNDING_BOX = "boundingBox",
10
    CONTENT_BOX = "contentBox",
11
    SKIN = "skin",
12
    _getClassName = Y.ClassNameManager.getClassName;
13
 
14
/**
15
 * Returns the name of the skin that's currently applied to the widget.
16
 *
17
 * Searches up the Widget's ancestor axis for, by default, a class
18
 * yui3-skin-(name), and returns the (name) portion. Otherwise, returns null.
19
 *
20
 * This is only really useful after the widget's DOM structure is in the
21
 * document, either by render or by progressive enhancement.
22
 *
23
 * @method getSkinName
24
 * @for Widget
25
 * @param {String} [skinPrefix] The prefix which the implementation uses for the skin
26
 * ("yui3-skin-" is the default).
27
 *
28
 * NOTE: skinPrefix will be used as part of a regular expression:
29
 *
30
 *     new RegExp('\\b' + skinPrefix + '(\\S+)')
31
 *
32
 * Although an unlikely use case, literal characters which may result in an invalid
33
 * regular expression should be escaped.
34
 *
35
 * @return {String} The name of the skin, or null, if a matching skin class is not found.
36
 */
37
 
38
Y.Widget.prototype.getSkinName = function (skinPrefix) {
39
 
40
    var root = this.get( CONTENT_BOX ) || this.get( BOUNDING_BOX ),
41
        match,
42
        search;
43
 
44
    skinPrefix = skinPrefix || _getClassName(SKIN, "");
45
 
46
    search = new RegExp( '\\b' + skinPrefix + '(\\S+)' );
47
 
48
    if ( root ) {
49
        root.ancestor( function ( node ) {
50
            match = node.get( 'className' ).match( search );
51
            return match;
52
        } );
53
    }
54
 
55
    return ( match ) ? match[1] : null;
56
};
57
 
58
 
59
}, '3.18.1', {"requires": ["widget-base"]});