OLD | NEW |
| (Empty) |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 /** | |
6 * @fileoverview | |
7 * Behavior controlling the visibility of Settings pages. | |
8 * | |
9 * Example: | |
10 * behaviors: [SettingsPageVisibility], | |
11 */ | |
12 | |
13 /** | |
14 * Set this to true in tests before loading the page (e.g. in preLoad()) so that | |
15 * pages do not initially get created. Set this to false BEFORE modifying | |
16 * pageVisibility. NOTE: Changing this value after the DOM is loaded will not | |
17 * trigger a visibility change, pageVisibility must be modified to trigger data | |
18 * binding events. | |
19 * @type {boolean} | |
20 */ | |
21 var settingsHidePagesByDefaultForTest; | |
22 | |
23 /** @polymerBehavior */ | |
24 var SettingsPageVisibility = { | |
25 properties: { | |
26 /** | |
27 * Dictionary defining page visibility. If not set for a page, visibility | |
28 * will default to true, unless settingsHidePagesByDefaultForTest is set | |
29 * in which case visibility defaults to false. | |
30 * @type {Object<boolean>} | |
31 */ | |
32 pageVisibility: { | |
33 type: Object, | |
34 value: function() { return {}; }, | |
35 }, | |
36 }, | |
37 | |
38 /** | |
39 * @param {boolean|undefined} visibility | |
40 * @return {boolean} | |
41 */ | |
42 showPage: function(visibility) { | |
43 if (settingsHidePagesByDefaultForTest) | |
44 return visibility === true; | |
45 return visibility !== false; | |
46 }, | |
47 }; | |
OLD | NEW |