forked from ibm-js/deliteful
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathToggleButton.js
84 lines (78 loc) · 3.45 KB
/
ToggleButton.js
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
78
79
80
81
82
83
84
/** @module deliteful/ToggleButton */
define([
"dcl/dcl",
"delite/register",
"requirejs-dplugins/has",
"./Button",
"./Toggle",
"requirejs-dplugins/has!bidi?./ToggleButton/bidi/ToggleButton",
"delite/handlebars!./ToggleButton/ToggleButton.html",
"delite/theme!./ToggleButton/themes/{{theme}}/ToggleButton.css"
], function (dcl, register, has, Button, Toggle, BidiToggleButton, template) {
/**
* A 2-state toggle button widget that represents a form-aware 2-states (pressed or unpressed) button with optional
* icons and labels for each state.
*
* A toggle button can display a different label depending on its state. By default, the label specified inline
* in the markup or via the 'label' property is displayed whatever the state is. It is however possible to set a
* label specific to the checked state via the 'checkedLabel' property.
*
* Similarly, a toggle button can display a different icon depending on its state. By default, the css class
* specified by the 'iconClass' property is applied whatever the state is. However, a css class specific to the
* checked state can be specified via the 'checkedIconClass' property.
*
* Moreover, a toggle button can show an icon only with no visible text, independently of
* the toggle button's state, checked or unchecked. To accomplish that,
* set the `showLabel` property (inherited from the `deliteful/Button` class). to `false`.
*
* @example <caption>Creating a checked toggle button</caption>
* <button is="d-toggle-button" checked="true">Foo</button>
* @example <caption>Specify a label for the checked state</caption>
* <button is="d-toggle-button" checked="true" checkedLabel="On">Off</button>
* @example <caption>Specify an icon for the checked state</caption>
* <style>
* .iconOn {
* background-image: url('images/on.png');
* width: 16px;
* height: 16px;
* }
* </style>
* <button is="d-toggle-button" checked="true" checkedIconClass="iconOn">Off</button>
* @class module:deliteful/ToggleButton
* @augments module:deliteful/Toggle
* @augments module:deliteful/Button.Mixin
*/
var ToggleButton = dcl([Button.Impl, Toggle], /** @lends module:deliteful/ToggleButton# */ {
/**
* The component css base class.
* @member {string}
* @default "d-toggle-button"
*/
baseClass: "d-toggle-button",
/**
* The label to display when the button is checked. If not specified, the default label (either the one
* specified inline in markup or via the 'label' property) is used for both states.
* @member {string}
* @default ""
*/
checkedLabel: "",
/**
* The name of the CSS class to apply to DOMNode in button to make it display an icon when the button is
* checked. If not specified, the class specified in the 'iconClass' property, if any, is used for both states.
* @member {string}
* @default ""
*/
checkedIconClass: "",
template: template,
refreshRendering: function (props) {
/* jshint maxcomplexity: 11 */
if (("label" in props || "checkedLabel" in props || "showLabel" in props || "checked" in props) &&
(!this.title || this.title === ("label" in props ? props.label : this.label)
|| this.title === ("checkedLabel" in props ? props.checkedLabel : this.checkedLabel))) {
this.title = this.showLabel ? "" : (this.checked ? this.checkedLabel : this.label);
}
}
});
return register("d-toggle-button", has("bidi") ? [HTMLButtonElement, ToggleButton, BidiToggleButton] :
[HTMLButtonElement, ToggleButton]);
});