123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- "use strict";
- define(['./MenuWithTick', 'underscore'], function (MenuWithTick, _) {
- 'use strict';
- var ToggleMenuBar = null;
-
- ToggleMenuBar = MenuWithTick.extend({
- itemMap: {},
- sCheckedItemName: null,
- updateLabel: false,
-
- init: function init(spec) {
- _.extend(this, spec);
- ToggleMenuBar.inherited('init', this, arguments);
- },
- toggleHandler: function toggleHandler(name) {
- this.updateSelectedItem(name);
- },
-
- updateSelectedItem: function updateSelectedItem(name) {
- var item = this.itemMap[name];
- if (!item || !item.children) {
-
- return;
- }
- if (this.sCheckedItemName) {
-
- this.updateMenuItemTick(this.itemMap[this.sCheckedItemName], false);
- }
- this.sCheckedItemName = name;
- this.updateMenuItemTick(this.itemMap[this.sCheckedItemName], true);
- if (this.updateLabel) {
- if (this.$menuLabel.length > 0 && item.children) {
- this.$menuLabel.text(item.children('a').attr('aria-label'));
- }
- }
- },
- render: function render() {
- var promise = ToggleMenuBar.inherited('render', this, arguments);
- if (this.updateLabel) {
- _.each(this.items, function (item) {
- if (item.checked) {
- this.updateSelectedItem(item.name);
- }
- }.bind(this));
- if (!this.sCheckedItemName) {
- this.updateSelectedItem(this.items[0].name);
- }
- }
- return promise;
- },
- _performAction: function _performAction(id) {
- this.updateSelectedItem(this._getItemNameFromID(id));
- ToggleMenuBar.inherited('_performAction', this, arguments);
- },
- _getItemNameFromID: function _getItemNameFromID(id) {
- var prefix = this.viewId + '_';
- return id.substr(prefix.length);
- },
- _buildDropDown: function _buildDropDown() {
- var promise = ToggleMenuBar.inherited('_buildDropDown', this, arguments);
- _.each(this.items, function (item) {
- var id = this._getItemId(item.name);
- this.itemMap[item.name] = this.$menu.find('#' + id);
- if (item.checked) {
- this.sCheckedItemName = item.name;
- }
- }.bind(this));
- this.updateMenuItemTick(this.itemMap[this.sCheckedItemName], true);
- return promise;
- },
- remove: function remove() {
- _.each(this.itemMap, function (item) {
- if (item.remove) {
- item.remove();
- }
- });
- ToggleMenuBar.inherited('remove', this, arguments);
- }
- });
- return ToggleMenuBar;
- });
|