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
|
// Copyright 2016 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
Polymer({
is: 'controlled-radio-button',
behaviors: [
PrefControlBehavior,
CrRadioButtonBehavior,
],
properties: {
disabled: {
type: Boolean,
computed: 'computeDisabled_(pref.*)',
reflectToAttribute: true,
observer: 'disabledChanged_',
},
name: {
type: String,
notify: true,
},
},
/**
* @return {boolean} Whether the button is disabled.
* @private
*/
computeDisabled_: function() {
return this.pref.enforcement == chrome.settingsPrivate.Enforcement.ENFORCED;
},
/**
* @param {boolean} current
* @param {boolean} previous
* @private
*/
disabledChanged_: function(current, previous) {
if (previous === undefined && !this.disabled)
return;
this.setAttribute('tabindex', this.disabled ? -1 : 0);
this.setAttribute('aria-disabled', this.disabled ? 'true' : 'false');
},
/**
* @return {boolean}
* @private
*/
showIndicator_: function() {
return this.disabled &&
this.name == Settings.PrefUtil.prefToString(assert(this.pref));
},
/**
* @param {!Event} e
* @private
*/
onIndicatorTap_: function(e) {
// Disallow <controlled-radio-button on-click="..."> when disabled.
e.preventDefault();
e.stopPropagation();
},
});
|