foam-framework
Version:
MVC metaprogramming framework
113 lines (107 loc) • 3.19 kB
JavaScript
/**
* @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; }
*/},
],
});