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.
7 * Size of additional padding in the inner scrollable section of the dropdown.
9 var DROPDOWN_INNER_PADDING
= 12;
11 /** Size of vertical padding on the outer #dropdown element. */
12 var DROPDOWN_OUTER_PADDING
= 2;
14 /** Minimum height of toolbar dropdowns (px). */
15 var MIN_DROPDOWN_HEIGHT
= 300;
18 is
: 'viewer-toolbar-dropdown',
21 /** String to be displayed at the top of the dropdown. */
24 /** Icon to display when the dropdown is closed. */
27 /** Icon to display when the dropdown is open. */
30 /** True if the dropdown is currently open. */
36 /** Toolbar icon currently being displayed. */
39 computed
: 'computeIcon_(dropdownOpen, closedIcon, openIcon)'
42 /** Lowest vertical point that the dropdown should occupy (px). */
45 observer
: 'lowerBoundChanged_'
49 * True if the max-height CSS property for the dropdown scroll container
50 * is valid. If false, the height will be updated the next time the
51 * dropdown is visible.
53 maxHeightValid_
: false,
55 /** Current animation being played, or null if there is none. */
59 computeIcon_: function(dropdownOpen
, closedIcon
, openIcon
) {
60 return dropdownOpen
? openIcon
: closedIcon
;
63 lowerBoundChanged_: function() {
64 this.maxHeightValid_
= false;
65 if (this.dropdownOpen
)
66 this.updateMaxHeight();
69 toggleDropdown: function() {
70 this.dropdownOpen
= !this.dropdownOpen
;
71 if (this.dropdownOpen
) {
72 this.$.icon
.classList
.add('open');
73 this.$.dropdown
.style
.display
= 'block';
74 if (!this.maxHeightValid_
)
75 this.updateMaxHeight();
77 this.$.icon
.classList
.remove('open');
79 this.cancelAnimation_();
80 this.playAnimation_(this.dropdownOpen
);
83 updateMaxHeight: function() {
84 var scrollContainer
= this.$['scroll-container'];
85 var height
= this.lowerBound
-
86 scrollContainer
.getBoundingClientRect().top
-
87 DROPDOWN_INNER_PADDING
;
88 height
= Math
.max(height
, MIN_DROPDOWN_HEIGHT
);
89 scrollContainer
.style
.maxHeight
= height
+ 'px';
90 this.maxHeightValid_
= true;
93 cancelAnimation_: function() {
95 this._animation
.cancel();
99 * Start an animation on the dropdown.
100 * @param {boolean} isEntry True to play entry animation, false to play
104 playAnimation_: function(isEntry
) {
105 this.animation_
= isEntry
? this.animateEntry_() : this.animateExit_();
106 this.animation_
.onfinish = function() {
107 this.animation_
= null;
108 if (!this.dropdownOpen
)
109 this.$.dropdown
.style
.display
= 'none';
113 animateEntry_: function() {
114 var maxHeight
= this.$.dropdown
.getBoundingClientRect().height
-
115 DROPDOWN_OUTER_PADDING
;
120 var fade
= new KeyframeEffect(this.$.dropdown
, [
123 ], {duration
: 150, easing
: 'cubic-bezier(0, 0, 0.2, 1)'});
124 var slide
= new KeyframeEffect(this.$.dropdown
, [
125 {height
: '20px', transform
: 'translateY(-10px)'},
126 {height
: maxHeight
+ 'px', transform
: 'translateY(0)'}
127 ], {duration
: 250, easing
: 'cubic-bezier(0, 0, 0.2, 1)'});
129 return document
.timeline
.play(new GroupEffect([fade
, slide
]));
132 animateExit_: function() {
133 return this.$.dropdown
.animate([
134 {transform
: 'translateY(0)', opacity
: 1},
135 {transform
: 'translateY(-5px)', opacity
: 0}
136 ], {duration
: 100, easing
: 'cubic-bezier(0.4, 0, 1, 1)'});