| // Copyright 2015 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. |
| |
| /** |
| * @fileoverview |
| * 'settings-menu' shows a menu with a hardcoded set of pages and subpages. |
| */ |
| Polymer({ |
| is: 'settings-menu', |
| |
| behaviors: [settings.RouteObserverBehavior], |
| |
| properties: { |
| advancedOpened: { |
| type: Boolean, |
| notify: true, |
| }, |
| |
| /** |
| * Dictionary defining page visibility. |
| * @type {!GuestModePageVisibility} |
| */ |
| pageVisibility: Object, |
| }, |
| |
| listeners: { |
| 'topMenu.tap': 'onLinkTap_', |
| 'subMenu.tap': 'onLinkTap_', |
| }, |
| |
| /** @param {!settings.Route} newRoute */ |
| currentRouteChanged: function(newRoute) { |
| const currentPath = newRoute.path; |
| |
| // Focus the initially selected path. |
| const anchors = this.root.querySelectorAll('a'); |
| for (let i = 0; i < anchors.length; ++i) { |
| if (anchors[i].getAttribute('href') == currentPath) { |
| this.setSelectedUrl_(anchors[i].href); |
| return; |
| } |
| } |
| |
| this.setSelectedUrl_(''); // Nothing is selected. |
| }, |
| |
| /** |
| * Prevent clicks on sidebar items from navigating. These are only links for |
| * accessibility purposes, taps are handled separately by <iron-selector>. |
| * @param {!Event} event |
| * @private |
| */ |
| onLinkTap_: function(event) { |
| if (event.target.hasAttribute('href')) |
| event.preventDefault(); |
| }, |
| |
| /** |
| * Keeps both menus in sync. |url| needs to come from |element.href| because |
| * |iron-list| uses the entire url. Using |getAttribute| will not work. |
| * @param {string} url |
| */ |
| setSelectedUrl_: function(url) { |
| this.$.topMenu.selected = this.$.subMenu.selected = url; |
| }, |
| |
| /** |
| * @param {!Event} event |
| * @private |
| */ |
| onSelectorActivate_: function(event) { |
| this.setSelectedUrl_(event.detail.selected); |
| |
| const path = new URL(event.detail.selected).pathname; |
| const route = settings.getRouteForPath(path); |
| assert(route, 'settings-menu has an entry with an invalid route.'); |
| settings.navigateTo( |
| route, /* dynamicParams */ null, /* removeSearch */ true); |
| }, |
| |
| /** |
| * @param {boolean} opened Whether the menu is expanded. |
| * @return {string} Which icon to use. |
| * @private |
| * */ |
| arrowState_: function(opened) { |
| return opened ? 'cr:arrow-drop-up' : 'cr:arrow-drop-down'; |
| }, |
| }); |