UNPKG

foam-framework

Version:
113 lines (107 loc) 3.19 kB
/** * @license * Copyright 2015 Google Inc. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 */ CLASS({ package: 'foam.ui.md', name: 'OverflowActionList', extends: 'foam.ui.SimpleView', requires: [ 'foam.ui.ActionButton', 'foam.ui.md.ActionList', 'foam.ui.md.OverlayDropdownView', ], properties: [ { model_: 'ArrayProperty', subType: 'foam.ui.md.ToolbarAction', name: 'data', postSet: function(old, nu) { if ( old === nu ) return; if ( nu.length === this.maxShowActions + 1 ) { // Edge case: More actions dropdown would lead to exactly one more // action. Just show that action instead. this.showActions_ = nu.slice(); this.moreActions_ = []; } else { this.showActions_ = nu.slice(0, this.maxShowActions); this.moreActions_ = nu.slice(this.maxShowActions); } }, }, { model_: 'IntProperty', name: 'maxShowActions', defaultValue: 4, }, { name: 'showActionList', lazyFactory: function() { return this.ActionList.create({ data$: this.showActions_$, direction: 'HORIZONTAL', actionViewFactory: this.ActionButton, }, this.Y); }, }, { model_: 'ViewFactoryProperty', name: 'moreActionsFactory', defaultValue: 'foam.ui.ActionButton', }, { type: 'foam.ui.md.OverlayDropdownView', name: 'moreActionsDropdown', lazyFactory: function() { return this.OverlayDropdownView.create({ data$: this.moreActions_$, delegate: this.ActionList.xbind({ direction: 'VERTICAL', actionViewFactory: this.moreActionsFactory, }, this.Y), }, this.Y); }, }, { model_: 'ArrayProperty', subType: 'foam.ui.md.ToolbarAction', name: 'showActions_', }, { model_: 'ArrayProperty', subType: 'foam.ui.md.ToolbarAction', name: 'moreActions_', }, ], actions: [ { name: 'moreActions', // TODO(markdittmer): This URL is for menus, not "more actions". iconUrl: '', ligature: 'more_vert', code: function() { this.moreActionsDropdown.open(); }, }, ], templates: [ function toHTML() {/* <actions id="%%id" %%cssClassAttr()> %%moreActionsDropdown %%showActionList $$moreActions{ extraClassName: 'more-actions-button' } <% this.setClass('hide-more-actions', function() { return this.moreActions_.length === 0; }.bind(this), this.moreActionsView.id); %> </actions> */}, function CSS() {/* actions flat-button.hide-more-actions { display: none; } actions flat-button.more-actions-button { margin-left: 0; } */}, ], });