1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
/* <copyright>
This file contains proprietary software owned by Motorola Mobility, Inc.<br/>
No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.<br/>
(c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
</copyright> */
/**
@module "montage/ui/bluemoon/button-group.reel"
@requires montage/core/core
@requires "ui/component-group.reel"
*/
var Montage = require("montage").Montage,
ComponentGroup = require("ui/component-group.reel").ComponentGroup;
/**
@class module:"montage/ui/bluemoon/button-group.reel".ButtonGroup
@classdesc A group of buttons, displayed "pill" style.
@extends module:montage/ui/component.Component
*/
var ButtonGroup = exports.ButtonGroup = Montage.create(ComponentGroup, /** @lends module:"montage/ui/bluemoon/button-group.reel".ButtonGroup */ {
/**
Description TODO
@type {Boolean}
@default true
*/
hasTemplate: {
value: true
},
/**
Description TODO
@private
*/
_iconic: {
value: false
},
/**
Sets wether or not to hide button text for buttons with icons.
@type {Function}
@default {Boolean} false
*/
iconic: {
get: function() {
return this._iconic;
},
set: function(value) {
if (this._iconic !== value) {
this._iconic = value;
this.needsDraw = true;
}
}
},
/**
Description TODO
@function
*/
prepareForDraw: {
value: function() {
this.element.classList.add("montage-button-group");
}
},
/**
Description TODO
@function
*/
draw: {
value: function() {
if (this._iconic) {
this.element.classList.add("iconic");
} else {
this.element.classList.remove("iconic");
}
}
}
});
|